题目概述
解题思路
比如16+9我们会怎么加呢
步骤1:先不进位,算出结果为 16+9=15(没有进位)
步骤2:找出进位的位置,9+6会产生进位,也就是个位1,左移一位成为十位是进位10
步骤3:将没有进位的结果加上进位的结果 15+10 = 25
你可能会问:上面的步骤和解决这道题目有什么关系呢?
题目不让用加减乘除,但是可以用位运算求解
异或所得到的结果是不带进位的结果
而与运算的结果是标记的是进位是哪一位
相加,即可求和
举例
比如17和5
17的二进制为10001
5的二进制为101
第一步:异或,得到结果为 sum = 10100
第二步:与运算,结果为00001,左移一位为 tmp = 00010
第三步:sum+tmp = 10110,为22,结果正确
注意:这里需要循环求解,因为第三步又会转换成两个数相加的情况
循环的终止条件是被加数为0时
代码实现
//采用位运算来求解
//0+0=0,1+1=0,1+0=1,0+1=1 异或可以算出没有进位的结果
//与运算算出需要进位的是哪些位,然后左移一位求出需要进位的对应位
//循环,继续相加
int Add(int x, int y)
{
int sum = 0;
int tmp = 0;
do
{
sum = x^y;
tmp = (x&y) << 1;
x = sum;
y = tmp;
} while (y != 0);
return x;
}