【日常训练】371. 两整数之和

本文介绍了一种不依赖于加减运算符的整数相加技巧,利用按位操作实现,通过逐位处理并进位,适用于LeetCode第371题。代码示例展示了如何通过异或(XOR)和按位左移(<<)操作巧妙计算两整数之和。

题目

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

示例 1:

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

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

提示:

-1000 <= a, b <= 1000

代码

package leetcodeday1;

public class leetcode371 {
    // 投机取巧
//    public int getSum(int a, int b) {
//        double x = Math.pow(10, a);
//        double y = Math.pow(10, b);
//
//        return (int) Math.log10(x * y);
//    }

    /**
     * 通过& 我们可以知道两数相加后需要进位的部分,进位后为x
     * 通过^ 我们可以找到两数相加后不需要进位的部分,相加为y
     *
     * 这样我就将a+b转换为了x+y,重复上述操作,直到无须进位
     * @param a
     * @param b
     * @return
     */
    public int getSum(int a, int b) {
        // 找出需要进位的点
        while ((a & b) != 0){
            // 进位
            int t = (a & b) << 1;
            // 找到无须进位的点相加
            b = a ^ b;
            a = t;
        }
        return a ^ b;
    }
    public static void main(String[] args) {
        leetcode371 obj = new leetcode371();
        System.out.println(obj.getSum(1, 2));
    }
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值