只用一次+ 求三个整数之和

http://www.1point3acres.com/bbs/thread-37291-1-1.html


int sum(int a, int b, int c) {
    int two = (a | b | c) & ~(a ^ b ^c);//(a|b|c)表示这三个数只要有一个位上为1,则为1;a^b^c 只保留了奇数个1的位,取反,就是有偶数个1的位,比如0个1或者2个1;最后的式子只保留两个1的位
    int three = a & b & c;//保留三个1的位
    int one = (a|b|c) ^ two ^ three;//只剩下 只有1个1的位
    return (one | three) + ((two | three) <<1);//


}


如何只用位运算实现两数相加


int sum(int a, int b) {

if (b == 0)

return a;

return sum((a^b, (a&b)<<1));

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值