不用加减乘除做加法
题目描述
写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。
分三步走:例如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;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· 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