欢迎访问 生活随笔!

生活随笔

当前位置: 首页 >

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

发布时间:2024/9/30 50 豆豆
生活随笔 收集整理的这篇文章主要介绍了 只用一次+ 求三个整数之和 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

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));

}

总结

以上是生活随笔为你收集整理的只用一次+ 求三个整数之和的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。