LeetCode Problem-Sum of Two Integers

这道题挺经典的,之前自学python的时候看过这样一个例子,这里记录一下思路。

题目描述:

给定两个整数,实现a + b但不用 + 或 - 操作符

思路

一开始可能会觉得奇怪,不给使用四则运算还玩什么?但这是计算机问题,可以回顾一下加法和减法的具体操作(减法是加法的逆运算,视为同理)
对于 a + b = c 而言,不妨以十进制举例,对于 15 + 17 = 32而言,可以先视作
1.按位相加
2.根据有无进位继续做加和
从底层实现的角度来看,这里跟 加法器 的原理是一致的,只是底层是二进制而不是十进制罢了。
半加器原理:
S = ~A & B + A & ~B = A^B (按位加和)
C = A & B (进位判断)
因为存在进位的情况,所以在这道题的实现中,需要在相加之后做一个 << 1 操作,总代码实现如下

 int getSum(int a, int b) {
    if(b == 0)return a;
    int carry = (a & b) << 1;
    int sum = a ^ b;
    return getSum(sum,carry);
    
}
复制代码
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值