【面试题】剑指Offer-47-不用加减乘除做加法

题目概述


解题思路

比如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;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值