不用加减乘除做加法

题目描述

写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。
分三步走:例如5+17=22;
先把5和17相加,但不计算进位:101+10001=10100(1+1=0,0+1=1 , 1+0=1,0+0=0相当于异或)
然后把进位加上,进位是二进制的10,所以最后结果10100+10=10110(22)
进位:只有1+1才有进位,相当于先位与运算,然后左移一位 
public class Solution {
    public int Add(int num1,int num2) {
        while (num2 != 0) {
            int temp = num1 ^ num2; //无进位的相加
            num2 = (num1 & num2) << 1; //计算进位值,直到不产生进位,计算结束
            num1 = temp;
        }
        return num1;
    }
}
posted @   MarkLeeBYR  阅读(101)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示