[CareerCup] 18.1 Add Two Numbers 两数相加

简介:

18.1 Write a function that adds two numbers. You should not use + or any arithmetic operators.

这道题让我们实现两数相加,但是不能用加号或者其他什么数学运算符号,那么我们只能回归计算机运算的本质,位操作Bit Manipulation,我们在做加法运算的时候,每位相加之后可能会有进位Carry产生,然后在下一位计算时需要加上进位一起运算,那么我们能不能将两部分拆开呢,我们来看一个例子759+674

1. 如果我们不考虑进位,可以得到323

2. 如果我们只考虑进位,可以得到1110

3. 我们把上面两个数字假期323+1110=1433就是最终结果了

然后我们进一步分析,如果得到上面的第一第二种情况,我们在二进制下来看,不考虑进位的加,0+0=0, 0+1=1, 1+0=1, 1+1=0,这就是异或的运算规则,如果只考虑进位的加0+0=0, 0+1=0, 1+0=0, 1+1=1,而这其实这就是与的运算,而第三步在将两者相加时,我们再递归调用这个算法,终止条件是当进位为0时,我们直接返回第一步的结果,参见代码如下:

int add(int a, int b) {
if (b == 0) return a;
int sum = a ^ b;
int carry = (a & b) << 1;
return add(sum, carry);
}

本文转自博客园Grandyang的博客,原文链接:两数相加[CareerCup] 18.1 Add Two Numbers ,如需转载请自行联系原博主。

相关文章
|
3月前
|
存储 算法 Java
LeetCode算法题---两数相加(二)
LeetCode算法题---两数相加(二)
24 0
|
3月前
leetcode-258:各位相加
leetcode-258:各位相加
20 0
|
7月前
|
存储 缓存 算法
【手绘算法】力扣 2 两数相加(Add Two Numbers)
Hi,大家好,我是Tom。一个美术生转到Java开发的程序员。今天给大家分享的是力扣题第2题,求两数相加。在解题过程中,也会手写一些伪代码。当然,如果想要完整的源码的话,可以到我的个人主页简介中获取。 这道题属于中等难度,通过率只有42%。
53 0
|
10月前
力扣--字符串相加
力扣--字符串相加
|
10月前
力扣--字符串相乘
力扣--字符串相乘
|
11月前
|
算法 索引
LeetCode每日1题--四数相加 II
LeetCode每日1题--四数相加 II
81 0
|
11月前
|
存储 算法 索引
LeetCode每日1题--两数之和
LeetCode每日1题--两数之和
71 0
|
存储 算法 Java
LeetCode 27移除元素&28实现strStr()&29两数相除
给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。 不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。 元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。
77 0
LeetCode 27移除元素&28实现strStr()&29两数相除
|
存储 算法 Java
【LeetCode:02 两数相加】
【LeetCode:02 两数相加】
105 0
|
存储 Java Python
LeetCode 2:两数相加 Add Two Numbers
​给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
667 0