本文主要是介绍每日OJ题_位运算⑤_力扣371. 两整数之和,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
力扣371. 两整数之和
解析代码
力扣371. 两整数之和
371. 两整数之和
难度 简单
给你两个整数 a
和 b
,不使用 运算符 +
和 -
,计算并返回两整数之和。
示例 1:
输入:a = 1, b = 2 输出:3
示例 2:
输入:a = 2, b = 3 输出:5
提示:
-1000 <= a, b <= 1000
class Solution {
public:int getSum(int a, int b) {}
};
解析代码
此题知识点就是异或运算为无进位相加,异或后想办法找到进位就行了,进位就是两个数按位与然后左移一位,重复相加至进位为0即为答案。
class Solution {
public:int getSum(int a, int b) {while (b != 0){unsigned int carry = (unsigned int)(a & b) << 1; // 进位a = a ^ b; // 无进位相加b = carry; // 进位不为0的话就一直加,如a已经是a^b的结果,再^b,加进位}return a;}
};
这篇关于每日OJ题_位运算⑤_力扣371. 两整数之和的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!