在不使用临时变量的情况下交换两个变量的值是一个经典的编程问题。在 C 语言中解决这个问题的一个优雅的解决方案是使用按位异或运算。
考虑两个变量 a 和 b。目标是交换他们的价值观。
用要交换的值初始化a和b。
执行以下步骤:
a^=b; b^=a; a^=b;
让我们一步步分解算法:
a ^= b;:将 a 与 b 进行异或 (^=) 并将结果存储回 a 中。执行此操作后,a 包含 XOR b 的结果。
b ^= a;:将 b 与 a 的新值(b 的原始值)进行异或。经过此操作,b 包含 b XOR (a XOR b) 的结果,简化为 a.
a ^= b;:将 a 与 b 的新值(a 的原始值)进行异或。执行此操作后,a 包含 (a XOR b) XOR a 的结果,简化为 b.
现在,a 保存了 b 的原始值,b 保存了 a 的原始值,无需使用临时变量即可有效交换它们的值。
考虑以下示例:
int a = 5,b = 7; a^=b; b^=a; a^=b;