1. 与 &

与运算规则:

1 & 1 = 1
0 & 1 = 0
0 & 0 = 0

以1和5的与运算为例:
1的二进制为 001
5的二进制为 101
仅最后一位都为1,所以结果为001

1 & 5 = 1

2. 或 |

或运算规则:

1 | 1 = 1
1 | 0 = 1
0 | 0 = 0

以4和6的或运算为例:
4的二进制为 100
6的二进制为 110
仅最后一位都为0,所以结果为110

4 | 6 = 6

3. 异或 ^

异或运算规则:

1 ^ 0 = 1
1 ^ 1 = 0
0 ^ 0 = 0

以9和3的异或运算为例:
9的二进制为 1001
3的二进制为 0011
不相同的位数为右数第2、4位,所以结果为1010

9 ^ 3 = 10

4. 左移 << 右移 >>

左移

x << y的含义为:将x的二进制数向左移动y位
以1为例,
1向左移动一位后得二进制数10,向左移动二位后得二进制数100

1 << 1 = 2
1 << 2 = 4

右移

x >> y的含义为:将x的二进制数向右移动y位
以5为例,
5的二进制数101向右移动一位后得二进制数10,向右移动二位后得二进制数1

5 >> 1 = 2
5 >> 2 = 1

凭借以上内容可解出Leetcode 461.汉明距离

def hammingDistance(x, y):
      # 题目要求求出二进制位不同位置的数目
      # 首先通过异或运算得出不同的位数
      xor = x ^ y
      # 记录距离的变量dis
      dis = 0
      # 因对变量xor进行右移操作,当xor不为0时进行以下操作
      while xor:
      # 通过&1的操作,可判断二进制数的有数第一位是否为1
            if xor & 1:
      # 如果为1,dis变量+1
                  dis += 1
      # 对经过异或运算后的变量xor进行右移
            xor = xor >> 1
      return dis