leetcode 190. Reverse Bits

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?

Related problem: Reverse Integer

这道题很简答,就是做一个移位操作,其实也可以把整数转化二进制的字符串,然后反转字符串。

像这样的题很可能面试遇到。

代码如下:

public class Solution
{
    /*
     * 由于Java中没有无符号数的概念,所以要注意一下,下面是Java的移位运算符
     * << 左移运算符,num << 1,相当于num乘以2
     * >> 右移运算符,num >> 1,相当于num除以2
     * >>> 无符号右移,忽略符号位,空位都以0补齐
     * 
     * */
    // you need treat n as an unsigned value
    public int reverseBits(int n) 
    {
        int res=0;
        for(int i=0;i<32;i++)
        {
            if( (n&1)==1 )
            {
                res = (res<<1) +1;
                n = n>>>1;
            }else
            {
                res = res<<1;
                n = n>>>1;
            }
        }
        return res;
    }
}

下面是C++的做法,就是直接作位运算

代码如下:

#include <iostream>
#include <vector>
#include <string>
#include <map>
#include <cmath>
#include <algorithm>

using namespace std;

class Solution 
{
public:
    uint32_t  reverseBits(uint32_t n)
    {
        uint32_t result = 0;
        for (int i = 0; i < 32; i++)
        {
            result = (result << 1) + (n >> i & 1);
        }
        return result;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值