371 Sum of Two Integers
2016-09-08 19:48
323 查看
问题描述:Calculate
the sum of two integers a and b,
but you are not allowed to
use the operator
问题思路:加法可以拆解成两个步骤:不考虑进位,各位相加;各位计算进位与否。这个过程对十进制和二进制都满足。其中异或运算(半加运算)可实现第一步。第二步是与运算。
1. a和b只有做a^b和(a&b)<<1就是两步的结果
2. 然后对新的两个数相加,也就是重复第一步
3. 直到没有进位,也就是(a&b)<<1==0
the sum of two integers a and b,
but you are not allowed to
use the operator
+and
-.
问题思路:加法可以拆解成两个步骤:不考虑进位,各位相加;各位计算进位与否。这个过程对十进制和二进制都满足。其中异或运算(半加运算)可实现第一步。第二步是与运算。
1. a和b只有做a^b和(a&b)<<1就是两步的结果
2. 然后对新的两个数相加,也就是重复第一步
3. 直到没有进位,也就是(a&b)<<1==0
int getSum(int a, int b) { int c = 0; do { c = a^b; b = (a&b)<<1; a = c; } while(b); return c; }
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- 使用位运算实现网页中的过滤、筛选功能实例
- C++联合体转换成C#结构的实现方法
- C++高级程序员成长之路
- C++编写简单的打靶游戏
- C++ 自定义控件的移植问题
- C++变位词问题分析
- C/C++数据对齐详细解析
- C++基于栈实现铁轨问题
- C++中引用的使用总结
- 使用Lua来扩展C++程序的方法
- C++中调用Lua函数实例
- Lua和C++的通信流程代码实例
- C++的template模板中class与typename关键字的区别分析