LintCode A+B
来源:互联网 发布:主力资金知乎 编辑:程序博客网 时间:2024/04/29 21:52
给出两个整数a和b, 求他们的和, 但不能使用 + 等数学运算符。
注意事项
你不需要从输入流读入数据,只需要根据aplusb的两个参数a和b,计算他们的和并返回就行。
说明
a和b都是 32位 整数么?
是的
我可以使用位运算符么?
当然可以
样例
如果 a=1 并且 b=2,返回3
利用位运算。
1.先忽略进位计算a+b,结果为a^b(同为0或同为1,结果都是0,否则才是1);
2.再计算进位,只有两个1时才进位,所以结果为(a&b)<<1(左移一位,因为进位到高位);
3.然后把两个结果相加,这个相加依然利用前两步来做,知道两个加数有一个为0,直接返回另一个。
代码如下:
public class Solution { /* * @param : An integer * @param : An integer * @return: The sum of a and b */ public int aplusb(int a, int b) { // write your code here if(a==0)return b; if(b==0)return a; int x = a^b; int y= (a&b)<<1; return aplusb(x,y); }};
阅读全文
0 0
- LintCode-A + B 问题
- LintCode A+B
- Lintcode A+B问题
- LintCode-A + B 问题
- LintCode【容易】A+B
- LintCode A+b问题
- LintCode-A + B 问题
- lintcode -- A+B问题
- LintCode A+B
- Lintcode:A + B 问题
- LintCode之A+B问题
- Lintcode 1 A + B 问题
- LintCode | 1. A + B 问题
- 【LintCode】1、A + B问题
- LintCode 1.A + B 问题
- [Lintcode] #1 A + B 问题
- LintCode:A+B的和
- LintCode-(1)A + B 问题
- new关键字的用法
- JDK安装过程中JRE无法安装
- 【boost】boost::asio(4)——buffer用法
- maven聚合与继承实践
- Unable to inflate view tag without class attribute
- LintCode A+B
- 1024,祝各位程序员节快乐
- OSI网络模型与TCP/IP协议族
- Thrift原理简析(JAVA)
- Linux权限(鸟哥Linux私房菜读书笔记)
- LDAP用户导入Ambari
- 模拟练习
- java基础知识
- CSDN使用