两个变量交换值的方法 按位异或 快速交换两个变量。
2013-11-14 17:29
302 查看
第一种方法,大家会借助第三个变量来实现:
如:tmp=A;A=B;B=tmp;
这种方法需要借助第三变量来实现;
第二种方法是利用加减法实现两个变量的交换,
如:A=A+B;B=A-B;A=A-B;
但是 如果 A+B 超出 A的返回 ,就会出错!极为不推荐 此方法
第三种方法是得用位异或运算来实现,也是效率最高的一种,在大量数据交换的时候,效率明显优于前两种方法,
如:A=A^B;B=A^B;A=A^B;
原理:利用一个数异或本身等于0和异或运算符合交换率。
异或的意思就是:不同 才可以得1,否则为0
// 异或
// 0^0=0
// 1^1=0
// 1^0=1
// 0^1=1
假如 a = 3,b = 4。想将a和b的值互换,可以用一下赋值语句实现:
a = a ^ b;
b = b ^ a;
a = a ^ b;
此方法 完美,推荐使用。
http://www.blogjava.net/landon/archive/2010/03/12/315301.html
如:tmp=A;A=B;B=tmp;
这种方法需要借助第三变量来实现;
第二种方法是利用加减法实现两个变量的交换,
如:A=A+B;B=A-B;A=A-B;
但是 如果 A+B 超出 A的返回 ,就会出错!极为不推荐 此方法
第三种方法是得用位异或运算来实现,也是效率最高的一种,在大量数据交换的时候,效率明显优于前两种方法,
如:A=A^B;B=A^B;A=A^B;
原理:利用一个数异或本身等于0和异或运算符合交换率。
异或的意思就是:不同 才可以得1,否则为0
// 异或
// 0^0=0
// 1^1=0
// 1^0=1
// 0^1=1
假如 a = 3,b = 4。想将a和b的值互换,可以用一下赋值语句实现:
a = a ^ b;
b = b ^ a;
a = a ^ b;
此方法 完美,推荐使用。
http://www.blogjava.net/landon/archive/2010/03/12/315301.html
相关文章推荐
- 不用中间变量,交换两个变量的值的方法
- 标准C语言,不用引入新变量就可以交换两个变量的方法及其注意事项
- 把两个变量交换数值的方法
- a ^= b ^= a ^= b看到了一个不需要中间变量交换两个的得方法
- Java交换两个变量的值的三种方法
- 两个变量交换值的几种方法
- [Z]用异或来交换两个变量是错误的
- 交换两个数,不用第三方变量(异或运算)
- 交换两个变量的值-三种方法
- 程序设计中利用“按位异或”运算交换两个变量的值原理
- [黑马程序员]对两个整数变量的值进行交换的方法总结
- 按位异或运算交换两个变量的值原理
- C语言基础—实现两个变量交换的三种方法
- 交换两个变量的值,不使用第三个变量的方法及实现
- 在不借助第三方变量情况下实现两个变量的交换(借助于异或运算)
- Java 如何用方法交换两个变量的值
- 交换两个变量的值(4种方法)
- 用C语言实现给定两个整形变量的值,将两个值的内容进行交换。(4种方法)
- 交换两个变量的三种方法
- java如何交换这两个变量的值方法介绍