位运算

作者: bigCatloveFish | 来源:发表于2018-11-25 20:57 被阅读5次
符号 描述 运算规则
& 1,1得1
| 两个0才是0。1,0为1。
^ 异或 相同为0,相异为1
~ 取反 ~0=1,~1=0
<< 左移 左移若干位高位丢弃,低位补0
>> 右移 右移若干位 高位补0

异或。

  1. 异或的规则。
x^0 = x
x^1s = ~x 
x^(~x) = 1s
x^x = 0
a^b = c => a^c = b ,b^c = a
a^b^c = a^(b^c)=(a^b)^c

2.常见的的操作

x&1==1 x&1==0 判断奇偶
x = x&(x-1)  清零最低位的1 
x&-x 得到最低位的1

3.复杂的操作

x&(~0<<n)  讲x右边n位清零
(x>>n)&1    获取x第n位的值
x&(1<<(n-1)) 获取x的第n位的幂值
x|(1<<n) 将第n位为1
x&(~(1<<n)) 将第n为为0
x&((1<<n)-1) x最高位至第n位清零
x&(~(1<<(n+1))-1)) 将第n位至第0位清零

例题

数字中1的个数

int hammingWeight(uint32_t n) {
    int number = 0;
    while(n>0){
        n = n&(n-1);
        number++;
    }
    return number;
 }

相关文章

  • 3、小众运算符の大课堂(一)

    较为简单の位运算符: & 位与运算| 位或运算^ 位异或运算~ 位取反运算 举例: 要做位运算,首先要把数据转...

  • 位运算及其应用

    内容概要: 位运算基本操作 基于位运算的状态压缩 位运算经典应用 位运算解N皇后问题 位运算 符号描述规则&与1&...

  • 位运算及用位运算实现权限控制

    请自行补习位运算相关知识 位运算 位运算示例 权限控制

  • 开发基础随笔之位运算符(Bitwise Operators)

    位运算符,属于算术运算符 按位逻辑运算符: 位移运算符: 位运算符的运算数只能是整数 位移运算符:按位左移 a<<...

  • 强大的位运算符

    位取反运算符 位取反运算符(~)是对所有位的数字进行取反操作位取反运算符.png 位与运算符 位与运算符(&)可以...

  • 位运算

    位运算 1. &:按位与 规律:一假则假任何位上的数和1相&得到的结果还是那个数 2. |:按位或 规律:一真则真...

  • 位运算

    https://leetcode.com/problems/gray-code/description/这个位运算...

  • 位运算

    位运算符比一般的算术运算符速度要快,而且可以实现一些算术运算符不能实现的功能。如果要开发高效率程序,位运算符是必不...

  • 位运算

    1.不用加减乘除做加法 解法:分为三步①各位相加不进位,即先按位异或;②做进位,按位与并左移位;③结果相加,直至没...

  • 位运算

    位运算不仅可以简化某些复杂的操作,而且具有更快的计算速度。典型的应用就是除法,交换两个数值,以及在一个数组中寻找只...

网友评论

      本文标题:位运算

      本文链接:https://www.haomeiwen.com/subject/bxipqqtx.html