位运算
- 基础知识
- leetcode 65
基础知识
正数的符号位为0、负数的符号位为1(最高位是符号位)
例子: +7 的 8位二进制原码是00000111, -7 的8位二进制原码是10000111。
所以在计算机中,通常都是采用 补码 形式
正整数的补码与原码形式相同,
例如 +7 的8位二进制 补码 是00000111;
负整数的补码:将这个负整数的绝对值求反码再加1,连同符号位1一起表示就可以了。
-7 的 8位二进制补码:将 -7 的绝对值 7 求反加 1 得 1111001,连同符号位1一起就是11111001。
& 0xFFFF FFFF
让任意一个整数 n & 0xFFFF FFFF 就能表示出任意一个数在计算机的表示方式!
判断一个二进制数有多少个1(n&(n-1),进行多少次与运算,该整数就有多少个1)
class Solution:
def NumberOf1(self, n):
if n < 0:
n = n & 0xFFFFFFFF
count = 0
while n:
count += 1 # 只要n不为0 就要记录一次,所以要写在前面,开始能进来就不为0
n = n & (n-1)
return count
leetcode65解题思路
无进位和 与 异或运算 规律相同,进位 和 与运算 规律相同(并需左移一位)
因此,无进位和 n 与 进位 c 的计算公式 如下:
和 s =(非进位和 n )+(进位 c )
class Solution(object):
def add(self, a, b):
"""
:type a: int
:type b: int
:rtype: int
"""
x=0xffffffff
a=a&x
b=b&x
while b!=0:
# c=a #c暂存a的值
# a=a^b #非进位和
# b=(c&b)<<1 & x #进位
a,b=a^b,(a&b)<<1 & x
return a if a<=0x7fffffff else ~(a^x)
python的负数存储
返回前数字还原: 若补码 a为负数( 0x7fffffff 是最大的正数的补码 ),需执行 ~(a ^ x) 操作,将补码还原至 Python 的存储格式。 a ^ x 运算将 1 至 32 位按位取反; ~ 运算是将整个数字取反;因此, ~(a ^ x) 是将 32 位以上的位取反,1 至 32 位不变。
Python里面需要将负数和0xffffffff进行与操作,来去掉负数前面的负号,可以理解为超过32位的东西就不进行考虑了,这进行与操作的具体步骤是:如果是正数,直接与;如果是负数,先去掉最前面的负号(&0xffffffff),再取反,再加1,再进行与操作。从而得到负数的补码。