不用加减乘除做加法(第48题)

题目描述

写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。

ac:100%

解题思路:
1、把两个数转换为二进制来处理,使用& ^ | <<运算符。假设A + B = C
2、使用& ^ |的意义:
     A & B的结果:1表示需要进位的位,0表示不需要进位的位
     A ^ B的结果:1表示不需要进位的位
     A | B的结果:得到两个数不进位相加的结果 
3、当A + B正好每位都不需要进位的时候:C = A | B
4、当A + B有需要进位的位的时候:设:
     n1 = A ^ B
     n2 = (A & B) << 1
5、A + B = n1 + n2
6、重复3、4,直到 n1 & n2 == 0(表示没有需要进位的位的时候,返回n1 | n2)

public int Add(int num1, int num2) {
		if((num1 & num2) == 0) {
			return num1 | num2;
		}
		
		int n1 = num1 ^ num2,n2 = (num1 & num2) << 1;
		
		while((n1 & n2) != 0) {
			num1 = n1 ^ n2;
			num2 = (n1 & n2) << 1;
			n1 = num1;
			n2 = num2;
		}
		
		return n1 | n2;
	}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值