【Leetcode 每日一题】371. 两整数之和 【中等】 位运算

给你两个整数 a 和 b ,不使用 运算符 + 和 - ​​​​​​​,计算并返回两整数之和。

示例 1:

输入:a = 1, b = 2
输出:3
示例 2:

输入:a = 2, b = 3
输出:5

提示:

-1000 <= a, b <= 1000

题解:
注意要使用无符号整数进行计算,本题目是模仿了计算机实现加法计算的方式,采用异或以及与操作。
可以发现,对于整数 a 和 b:
在不考虑进位的情况下,其无进位加法结果为 a ^ b。
而所有需要进位的位为 a & b,进位后的进位结果为 (a & b) << 1。

//写法1:
class Solution {
public:
    int getSum(int a, int b) {
        unsigned int x = a ^ b;
        unsigned int y = a & b;
        while(y != 0){
            unsigned int tmpx = x;
            unsigned int tmpy = y << 1;
            x = tmpx ^ tmpy;
            y = tmpx & tmpy;
        }
        return x;
    }
};
//写法2:
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;
        }
        return a;
    }
};
全部评论

相关推荐

07-15 11:41
门头沟学院 Java
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-11 11:21
被夸真的超级开心,好可爱的姐姐
码农索隆:老色批们不用脑补了,我把金智妮的图找来了查看图片
点赞 评论 收藏
分享
06-12 17:46
门头沟学院 Java
运营你豪哥:来说重点: ​1.项目前置,时间倒序。​​ 2.​项目描述强化结果与量化效果(STAR原则里的R)。​​ ​3.个人技能精炼,明确掌握程度,突出核心。​​ ​4.增加强有力开头的个人总结部分。​​ 5.​优化教育背景(成绩排名)、合并奖项与活动。​​
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务