java不使用第三变量交换两个变量的值
作者:天航星
这篇文章主要介绍了java不使用第三变量交换两个变量的值问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
不使用第三变量交换两个变量的值
在 Java 中,经常会需要交换两个变量的值,我们一般是使用第三变量完成
比如:
temp = a; a = b; b = temp;
这样的写法确实能达成目标,但因此而引入了第三变量,对资源的消耗增加了。
这里总结了两种不使用第三变量实现的方式
这两种方法仅为个人总结,不能断定只有这三种,非常希望大家能提出其他的方式,互相学习。
加减交换法
a = a + b; b = a - b; a = a - b;a = a + b; b = a - b; a = a - b;
这种方式还有更高级的写法:
a = a + b - (b = a);
这种写法确实达到了目标,但还只是数字层面的技巧,下面介绍一种计算机底层的方式。
异或运算法
异或运算平时用得较少,这里先介绍一下。
两个数进行异或运算,其实就是它们的二进制数每一位进行运算:相同为 0,不同为 1。
0 ^ 0 = 0;1 ^ 0 = 1;0 ^ 1 = 1;1 ^ 1 = 0;
由此可以得出异或的 3 个特点:
- 0 异或任何数 = 任何数
- 1异或任何数 = 任何数取反
- 任何数异或自己 = 把自己置0
异或的常见用途:
- 使某些特定的位翻转
例如对数 10100001 的第 2 位和第 3 位翻转,则可以将该数与 00000110 进行异或运算:
10100001 ^ 00000110 = 10100111
- 两个变量值的交换,而不必使用第三变量
这就是我们这里的需求了。
例如交换两个整数 a = 10100001,b = 00000110 的值, 可以这样实现:
a = a ^ b; // a = 10100111 b = b ^ a; // b = 10100001 a = a ^ b; // a = 00000110
以上过程等效于:
a = a ^ b; b = b ^ a = b ^ ( a ^ b ) = a ^ b ^ b = a ^ 0 = a; a = a ^ b = (a ^ b) ^ a = b ^ a ^ a = b ^ 0 = b;
这样就实现了两个变量值的交换。
更推荐这种方式,倒不因为这样写更高级,而是这样的二进制运算是最快的,执行效率最高。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。