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
- 如果我们不考虑进位,可以得到 323
- 如果我们只考虑进位,可以得到 1110
- 我们把上面两个数字加起来 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)