leetcode371: Sum of 2 Integers

本文介绍了一种不使用加减运算符实现两个整数相加的方法。通过异或操作实现二进制不带进位的加法,与操作得到进位,迭代直至无进位。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述:

Calculate the sum of two integers a and b, but you are not allowed to use the operator + and -.

Example:
Given a = 1 and b = 2, return 3.

网上流传最广的方法:

原理:使用异或操作可以进行二进制不带进位的加减,与操作可以得到进位。

即:

result0 = a ^ b

carry0 = (a & b) << 1

于是有:a + b = result0 + carry0

再进行一次迭代:

result1 = result0 ^ carry0

carry1 = (result0 & carry0) << 1

以此类推:有a + b = result0 + carry0 = result1 + carry1 = result2 + carry2 = ······ = resultN + carryN = result(N+1) ,直到carry(N+1)=0得到结果。

所以步骤是:
1、先让两个数字相加,但是不进位,即做异或的操作;
2、计算产生的进位,让两个数字位与操作,然后向左移动一位;
3、前两步的结果相加,重复前两个步骤直到进位为0;

很容易写出代码:

public class SumOf2Int {
	static int getSum(int a, int b) {
		int x, y;
		while (b != 0){
			x = a ^ b;
			y = (a & b) << 1;
			a = x; b = y;
		}
		return a;
	}
	public static void main(String[] args) {
		System.out.println(getSum(-15, -5));
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值