LintCode 1.A+B问题
问题描述
给出两个整数a和b, 求他们的和, 但不能使用 + 等数学运算符.
注意事项 你不需要从输入流读入数据,只需要根据aplusb的两个参数a和b,计算他们的和并返回就行。
说明
a和b都是 32位 整数么?
是的
我可以使用位运算符么?
当然可以
问题分析
很显然要用到位运算
代码
class Solution {
public:
/*
* @param : An integer
* @param : An integer
* @return: The sum of a and b
*/
int aplusb(int a, int b) {
// write your code here
return b ? aplusb(a^b,(a&b)<<1) : a;
}
};
参考链接:http://blog.csdn.net/hackbuteer1/article/details/7390093