---------------------------------------------
-- 时间:2018-12-17
-- 创建人:Ruo_Xiao
-- 邮箱:xclsoftware@163.com
---------------------------------------------
一、借助第三个变量实现
栗子:
tmp = A;
A = B;
B = tmp;
二、利用加减实现
1、栗子:
A = A + B;
B = A - B; //B相当于之前的A
A = A - B; //A相当于之前的B
2、容易造成变量A超过其上限。
三、利用按位异或实现
1、异或的原理:相同为0,不同为1。
2、异或的两个重要属性:
(1)异或自身为0。
(2)异或运算符合交换律,即:A^B = B^A。
3、栗子
A = A ^ B;
B = A ^ B; //B' = A ^ B ^ B = A;
A = A ^ B; //A = A ^ B ^ B'= A ^ B ^ A = B ^ A ^ A = B;
(SAW:Game Over!)
本文介绍了三种在编程中不使用额外变量进行变量交换的方法:通过第三个变量、利用加减操作和按位异或实现。每种方法都有其特点,如按位异或避免了额外变量的使用,但加减法可能引起数值溢出。
2万+

被折叠的 条评论
为什么被折叠?



