交换值而不使用第三个变量(Swapping values without using third variable)
优质
小牛编辑
139浏览
2023-12-01
在许多情况下,程序员需要交换两个变量的值。 在这里,我们将学习如何交换两个整数变量的值,这可能导致交换任何类型的值。 变量之间的值可以通过两种方式交换 -
- 在第三个(临时)变量的帮助下
- 不使用任何临时变量
我们已经学会了first method 。 在这里,我们将学习第二种方法。 虽然它看起来像魔术,但它只是一个小技巧。 想象一下,我们现在分别在a和b中存储了两个数字1和2 -
如果我们添加a和b(1 + 2)并将其存储到a然后a将变为3而b仍然是2。
现在我们从a(3)的新值中减去b(2)并将其存储到b然后a仍然是3而b变为1.注意1早先由a保持。
现在我们从a(3)中减去具有新值(1)的b并将其存储到b(a = 3 - 1)然后a保持先前由b保持的值2。
结论 - 交换值。
算法 (Algorithm)
我们现在将逐步算法的方式定义上述过程 -
START
Var1, Var2
Step 1 → Add Var1 and Var2 and store to Var1
Step 2 → Subtract Var2 from Var1 and store to Var2
Step 3 → Subtract Var2 from Var1 and store to Var1
STOP
伪代码 (Pseudocode)
从上面的算法,我们可以为这个程序绘制伪代码 -
procedure swap(a, b)
a ← a + b // a holds the sum of both
b ← a - b // b now holds the value of a
a ← a - b // a now holds value of b
end procedure
实现 (Implementation)
上述算法的C实现应该如下所示 -
#include <stdio.h>
int main() {
int a, b;
a = 11;
b = 99;
printf("Values before swapping - \n a = %d, b = %d \n\n", a, b);
a = a + b; // ( 11 + 99 = 110)
b = a - b; // ( 110 - 99 = 11)
a = a - b; // ( 110 - 11 = 99)
printf("Values after swapping - \n a = %d, b = %d \n", a, b);
}
输出 (Output)
该计划的输出应为 -
Values before swapping -
a = 11, b = 99
Values after swapping -
a = 99, b = 11