不用 +运算符 ,用位操作实现两数相加(原理+代码实现)

本文介绍了如何利用位操作符(如按位异或、按位与)来实现两个整数的相加,详细解释了异或作为不进位加法的原理,并提供了C、C++、Java和Python的代码实现。
摘要由CSDN通过智能技术生成

需要了解的基本概念:

按位操作符:

按位与&

按位异或^

按位左移<<(低位补0)

按位右移(无符号数以及有符号数的逻辑右移,采取高位补0,有符号数的算术右移采取高位补符号位)

异或也叫半加运算,其运算法则相当于不带进位的二进制加法:二进制下用1表示真,0表示假,则异或的运算法则为:0⊕0=0,1⊕0=1,0⊕1=1,1⊕1=0(同为0,异为1),这些法则与加法是相同的,只是不带进位,所以异或常被认作不进位加法

 

解决问题的方法:

  • 首先 将两个数按位异或,得到不含进位的和
  • 通过 按位与 来计算 进位,当两个数对应位都为1时产生进位,因此需将按位与的结果左移一位
  • 若进位不为零,则将 不含进位的和 跟 进位 再次从第1步开始迭代,否则返回结果

例如: 10+6 ,即 1010+0110

1.将 10100110 按位异或 ,得:1100

2.将 10100110 按位与, 得:0010 ,有进位,则左移,得 0100

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值