使用与或运算完成两个整数的相加

题目:有两个10进制整数,仅使用与或运算完成两个整数的相加。


C语言中有个很美好的功能叫“位操作”,位操作符有6种。

& 按位与
| 按位或
^ 按位异或
~ 取反
<< 左移  c=c<<1
>> 右移


考虑两个二进制数的相加,

1、将每位进行异或操作,操作之后得出的是不带进位加法的结果。

2、将每位进行与操作。当结果为1时说明该位产生进位。

3、将2的结果左移一位,得到的就是应该加在结果1上面的进位产生的数值。

4、用以上步骤进行1+3的操作,直到每一位都没有进位为止。


int main()
{
    int a=5,b=3;
	int c=0,time=0; /*c:存放进位,time:存放循环运行次数*/
	do
	{	
		c=a&b;
		c=c<<1;  /*进位数的总值*/
		b=a^b;	/*不带进位的加法*/
		a=c;
		time++;
	}while(c);
	printf("%d,run time=%d",b,time);
	return(0);
}


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值