剑指65:不用加减乘除做加法

位运算

  • 基础知识
  • 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,再进行与操作。从而得到负数的补码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值