Problem: Reverse bits of a given 32 bits unsigned integer.
For example, given input 43261596 (represented in binary as 00000010100101000001111010011100), return 964176192 (represented in binary as 00111001011110000010100101000000).
Follow up: If this function is called many times, how would you optimize it?
思路
输入数据向右移取最低位,结果变量与最低位进行或操作,再向左移
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
class Solution { public: uint32_treverseBits(uint32_t n){ int i=0; uint32_t ret=0; for(;i<32;i++) { int x=n&0x1; ret=ret<<1; ret=ret|(n&0x1); n=n>>1; } return ret; } };