剑指Offer-不用加减乘除做加法

题目描述#

写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。

思路#

思路一:

位运算

思路二:

递归

思路三:

调用Integer的sum方法

思路四:

自增自减

代码实现#

Copy
package Other; /** * 不用加减乘除做加法 * 写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。 * 思路:位运算 * 1.两个数异或:相当于每一位相加,而不考虑进位; * 2.两个数相与,并左移一位:相当于求得进位; * 3.将上述两步的结果相加 */ public class Solution14 { public static void main(String[] args) { Solution14 solution14 = new Solution14(); System.out.println(solution14.Add_4(2, -3)); } /** * 自增自减 * * @param num1 * @param num2 * @return */ public int Add_4(int num1, int num2) { if (num1 < 0) { while (num1++ != 0) { num2--; } } else if (num1 > 0) { while (num1-- != 0) { num2++; } } return num2; } /** * 调用Integer的sum方法 * * @param num1 * @param num2 * @return */ public int Add_3(int num1, int num2) { return Integer.sum(num1, num2); } /** * 递归 * * @param num1 * @param num2 * @return */ public int Add_2(int num1, int num2) { if (num2 == 0) return num1; return Add(num1 ^ num2, (num1 & num2) << 1); } /** * 位运算 * * @param num1 * @param num2 * @return */ public int Add(int num1, int num2) { while (num2 != 0) { int temp = num1 ^ num2;//执行加法 num2 = (num1 & num2) << 1;//进位操作 num1 = temp; } return num1; } }
posted @   武培轩  阅读(425)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示
CONTENTS