《程序员代码面试指南》

BitOperation

2020-02-03  本文已影响0人  coderjiege

不用额外变量交换两个整数的值

^ 相同0,不同1
^有一个特征,就是 abb = a

public void swap(int a, int b) {
    a = a ^ b;
    // b = (a ^ b) ^ b = a
    b = a ^ b;
    // a = (a ^ b) ^ a = b
    a = a ^ b;
}
上一篇 下一篇

猜你喜欢

热点阅读