剑指 Offer 65. 不用加减乘除做加法 C++位运算模拟加法

我们知道异或是不进位的加法,对于二进制来说,当某一位均为1时需要进位。

则a&b的值中位数为1的位表示需要进位,由于后面的进位不会超过1,则某一位最多进位1次。

a+b = a^b + (a&b)<<1;

这里的加法还是无法解决,但转化为了子问题,即可以递归解决。

当a||b为0时,结果显然。

class Solution {
public:
    int gao(int a,int b){
        if(a==0)return b;
        if(b==0)return a;
        //c++  左移运算符对默认是算术左移,需要改成无符号数变为逻辑左移形式
        return gao(a^b,(unsigned int)( a & b ) << 1);
    }
    int add(int a, int b) {
        return gao(a,b);
    }
};

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值