基本位运算的相关知识

基本位运算的相关知识,第1张

基本位运算的相关知识 前言

有这样一个笑话:

世界上有10种人,1种懂二进制,1种不懂二进制。

由于我用的是Java,所以使用其他语言的读者朋友们,すみません(sumimasen)

先了解一下位运算的知识:
与&:0&0=0 0&1=0 1&0=0 1&1=1
或|:0|0=0 0|1=1 1|0=1 1|1=1
异或^:0^0=0 0^1=1 1^0=1 1^1=0
取反~:~1=0 ~0=1
左移<<:左边的二进制位丢弃,右边补0
右移>>:正数左补0,负数左补1,右边丢弃符号左移<<<:左边的二进制位丢弃,右边补0
无符号右移>>>:忽略符号位,空位都以0补齐

有些讨厌,某些符号这里打不出来,就写在代码段中了。

题目:

颠倒给定的 32 位无符号整数的二进制位:

输入:n = 00000010100101000001111010011100
输出:964176192 (00111001011110000010100101000000)
解释:输入的二进制串 00000010100101000001111010011100 表示无符号整数 43261596,
     因此返回 964176192,其二进制表示形式为 00111001011110000010100101000000。

题解:

public class Solution{
    public int reverseBits(int n){
        int rev = 0;
        for(int i = 0;i<32&&n!=0;i++){
            rev|=(n&1)<<(31-i);
            n>>>=1;        
        }    
        return rev;
    }
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5707384.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存