[leetcode] 371. Sum of Two Integers

Description

Calculate the sum of two integers a and b, but you are not allowed to use the operator + and -.

Example 1:

Input:

a = 1, b = 2

Output:

3

Example 2:

Input:

a = -2, b = 3

Output: 1

分析

题目的意思是:给定a和b,求出a+b但是不能用+,-运算符。

  • 用与或非运算,这是个递归。

  • 例如: 759+674

  1. 如果我们不考虑进位,可以得到 323
  2. 如果我们只考虑进位,可以得到 1110
  3. 我们把上面两个数字加起来 323+1110=1433 就是最终结果了
  • 在二进制下来看,不考虑进位的加,0+0=0,0+1=1, 1+0=1,1+1=0,这就是异或的运算规则,如果只考虑进位的加 0+0=0, 0+1=0, 1+0=0, 1+1=1,而这其实这就是’与’的运算,而第三步在将两者相加时,我们再递归调用这个算法,终止条件是当进位为0时,直接返回第一步的结果。

C++实现

class Solution {
public:
    int getSum(int a, int b) {
        if(b==0){
            return a;
        }
        int sum=a^b;
        int carry=(a&b)<<1;
        return getSum(sum,carry);
    }
};

Python实现

这里为了考虑负数,所以用了mask。

  • 在不考虑进位的情况下,其无进位加法结果a^b
  • 所有需要进位的位为 a&b, 进位后的进位结果为 (a^b)<<1
class Solution:
    def getSum(self, a: int, b: int) -> int:
        mask=0xFFFFFFFF
        while b:
            carry = (a&b)&mask
            a = (a^b)&mask
            b = carry<<1&mask
        if a<0x7FFFFFFF:
            return a
        else:
            return ~(a^mask)

参考文献

[LeetCode] Sum of Two Integers 两数之和

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

农民小飞侠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值