位运算实现加法

a^b,即a+b,但是没有进位,原因:

  • 0^1 = 1,0+1=1
  • 1^0 = 1,1+0=1
  • 1^1 = 0,1+1=10
  • 0^0 = 0,0+0=0

a&b,得到的二进制数的每一位就是a+b需要进位的位,原因:

  • 0&1 = 0,0+1=1
  • 1&0 = 0,1+0=1
  • 1&1 = 1,1+1=10
  • 0&0 = 0,0+0=0

a<<1,将a的每一位都进位

那么思路来了:①先a^b得到没有进位的加法,②将需要进位的进位,③把前两个加起来;即:(a^b) + (a&b)<<1当然啦,这里不能用“+”,不过我们可以用递归

package com.vapy.offer;
/**
 *
 * @author vapy 2016年8月29日
 *
 */
public class Add {
    public static void main(String[] args) {
        System.out.println(add(23,-245));
    }

    public static int add(int num1, int num2) {
        if(0 == num2) {
            return num1;
        }
        //<<的优先级比&高,切记不能少括号
        return add(num1^num2, (num1&num2)<<1);
    }
}

结果:-222

本文代码可在github查看:点击此处

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值