交换两个数的值时,我们都知道,可以创建一个临时变量,然后通过直接交换两个数的数值。
直接交换数值
#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)
int main()
{
int a;
int b;
int count;
printf("请输入两个数:");
scanf("%d%d", &a, &b);
count = a;
a = b;
b = count;
printf("交换后:a=%d b=%d\n",a,b);
system("pause");
return 0;
}
除此以外,是否可以不创建第三变量实现交换呢?
使用数学加减运算交换数值
#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)
int main()
{
int a;
int b;
printf("请输入两个数:");
scanf("%d%d", &a, &b);
a = a + b;
b = a - b;
a = a - b;
printf("交换后:a=%d b=%d\n",a,b);
system("pause");
return 0;
}
将a和b的和存在a内,之后a-b得原来a的值赋予b,然后的a-b即得原来b的值,赋予a。
同理,乘除运算也可以。
#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)
int main()
{
int a;
int b;
printf("请输入两个数:");
scanf("%d%d", &a, &b);
a = a * b;
b = a / b;
a = a / b;
printf("交换后:a=%d b=%d\n",a,b);
system("pause");
return 0;
}
但是运用加减乘除算法进行交换时存在局限性的。
加减中,由于数据存储空间有限,如果数字的和太大,这样会造成溢出的状况,即a和b的取值是局限的。
乘除中,同样存在数字大小限制,同时如果再除数位上的数字为0.这样,程序显然也是走不下去的。
因此有时候就有必要采取另一种方法。
使用异或运算符进行交换
#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)
int main()
{
int a;
int b;
printf("请输入两个数:");
scanf("%d%d", &a, &b);
a = a ^ b;
b = a ^ b;
a = a ^ b;
printf("交换后:a=%d b=%d\n", a, b);
system("pause");
return 0;
}
在这里,异或的理解和上面加减的理解方式是差不多的。吧a ^ b的值赋给a,这样b=a ^ b中就相当于原来的a ^ b ^b,这样a的值就赋给了b;
同样的道理,在下一步中a=a ^ b 就相当于原来的a ^ b ^ a,这样b的值就赋给了a;这样也能达到数值的交换,并且没有过多的局限性。
但是,平时我们并不会经常选择下面两种,主要是因为程序编译时比较繁琐,并没有创建变量来的快捷和方便。