很多在面试或者其它考试的时候会遇到这样一道题,不借助于第三个变量而交换两个变量的值,开始的时候想想确实不知道应该怎样做,通常,我们借助于第三个变量的做法是:
int x = 3 , y = 8 ; |
int temp = x; |
x = y; |
y = temp; |
当然这是借助于第三个变量来的,下面不借助于第三个变量来进行交换
第一种方法:
int x = 3 , y = 8 ; |
x = x + y; //x = 11 |
y = x - y; //y = 11 - 8 = 3 |
x = x - y; //x = 11 - 3 = 8 |
这种方法通常也行得通,但是要注意,如果x和y数值比较大的话,比如x+y的值超过了int类型的取值范围就行不通了,下面再看第二种方法:
int x = 3 , y = 8 ; |
x = x ^ y; |
y = x ^ y; //相当于(x ^ y) ^ y = x |
x = x ^ y; //相当于(x ^ y) ^ (x ^ y) ^ y = y ^ x ^ x ^ y ^ y = y |
当然这里我们首先要明白一个定理,就是一个数异或另一个数两次,结果还是这个数,比如 3 ^ 8 ^ 8 = 3;大家可以自行尝试,这样就行了,当然或许还有其它的方法,有待于探索……