我是靠谱客的博主 活泼金毛,最近开发中收集的这篇文章主要介绍LeetCode 剑指 Offer 65. 不用加减乘除做加法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

原题链接
思路:不让使用一般加减运算符号当然是想到位运算。

  1. int 类型数在计算机中是使用补码存放,负数正数的加减规则一样,在计算的时候把有符号数看做无符号数计算,不然会报负值左移错误。
  2. 两个二进制数异或运算得到每一位进位以后剩下的,例如:二进制1与1异或,结果是二进制10,剩下的0。这一步结果是 ax。
  3. 两个二进制数与运算得到结果,表示这一位是否产生进位,如果产生进位,进位对应的是更高一位,对齐的操作是让二进制数左移一位。这一步结果是 bx。
  4. 然后再把 ax 和 bx 相加,重复操作2、操作3。
  5. 结束的标志是不在有任何进位产生,即bx的值为0

给出代码:

class Solution {
public:
int add(int a, int b) {
while( b != 0){
int ax = a^b;
int bx = unsigned (a & b) << 1;
a = ax;
b = bx;
}
return a;
}
};

最后

以上就是活泼金毛为你收集整理的LeetCode 剑指 Offer 65. 不用加减乘除做加法的全部内容,希望文章能够帮你解决LeetCode 剑指 Offer 65. 不用加减乘除做加法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(40)

评论列表共有 0 条评论

立即
投稿
返回
顶部