(leetcode算法题)371. 两整数之和

只使用 按位异或 和 按位与 和 左移操作,就能够实现两整数相加,不需要加减系列运算符

具体的原理如下,

首先a + b = (a ^ b) + ((a & b) << 1)

这是因为根据异或的定义,两个二进制数异或的结果实际上就是这两个数按照竖式计算时无进位相加的结果

而(a & b) << 1 就是两个数相加时产生的进位按位放置得到的结果,比如以103104 + 11408为例

0000 0000 0000 0000 0000 0001 0000 0000就是这两个数相加时会在第8位相加的时候因为产生了进位,而在第9位添加一个进位1

那么怎么来计算(103106 ^ 11408)+ ((103106 & 11408) << 1)?

还是使用相同的计算方法绕开 加法

即实现一个循环,直到进位为0时就可以结束循环

cpp 复制代码
class Solution {
public:
    int getSum(int a, int b) {
        while (b){
            int tmp1 = a ^ b;
            b = (a & b) << 1;
            a = tmp1;
        }
        return a;
    }
};
相关推荐
骑自行车的码农33 分钟前
🍂 React DOM树的构建原理和算法
javascript·算法·react.js
CoderYanger1 小时前
优选算法-优先级队列(堆):75.数据流中的第K大元素
java·开发语言·算法·leetcode·职场和发展·1024程序员节
希望有朝一日能如愿以偿1 小时前
力扣每日一题:能被k整除的最小整数
数据结构·算法·leetcode
Controller-Inversion1 小时前
力扣53最大字数组和
算法·leetcode·职场和发展
rit84324991 小时前
基于感知节点误差的TDOA定位算法
算法
m0_372257021 小时前
ID3 算法为什么可以用来优化决策树
算法·决策树·机器学习
q***25211 小时前
SpringMVC 请求参数接收
前端·javascript·算法
Dream it possible!1 小时前
LeetCode 面试经典 150_图_克隆图(90_133_C++_中等)(深度优先:DFS)
c++·leetcode·面试·
数模加油站2 小时前
25认证杯C题成品论文第一弹【冲奖硬核+无盲点解析】
算法·数学建模·认证杯·25认证杯
MobotStone2 小时前
数字沟通之道
人工智能·算法