- 题目描述
- 解题思路
- 解题代码
- 解法一:引入临时变量
- 解法二: 不使用临时变量,就自己操作
- 解法三: 使用异或运算(比较快速的高阶技法)
- 知识补充
- 解法四: 脑经急转弯
- 写在最后
解题思路循环输入两个数a 和 b,交换两者的值后输出 a 和 b。当没有任何输入时,结束程序。
解题代码 解法一:引入临时变量最基础的方法就是引入临时变量从而实现两个数字的交换,除此之外,其实还有别的方法,我们来一起看看。
#include解法二: 不使用临时变量,就自己操作int main() { int a, b; while( scanf("%d%d",&a,&b) != EOF ) { int temp = a;//ÕâÀïµÄtempΪÁÙʱ±äÁ¿£¬ÓÃÓÚÁÙʱ´æ·ÅÊý¾Ý a = b; b = temp; printf("%d %dn",a,b); } return 0; }
#includeint main() { int a, b; while( scanf("%d%d",&a,&b) != EOF ) { a = a + b; b = a - b; a = a - b; printf("%d %dn",a,b); } return 0; }
解法三: 使用异或运算(比较快速的高阶技法) 知识补充这里的先让a是a和b的和,那么减去b后再赋值给b,所以b的值就是a了。
然后再让a - b的值赋值给a,那么a - b得到的值是b,所以就等同于b赋值给a。
异或运算,运算规则是:
如果两个数字相同,那么异或的结果就是0,否则是1.
异或运算符号使用^来表示
例如: 1 ^ 1 = 0;
0 ^ 0 = 0;
1 ^ 0 = 1;
0 ^ 1 = 1
·从这里我们也可以看出来异或·运算满足交换律,要注意这是一个很厉害的结论,在以后会很有用处的。
整型数字在计算机中是以二进制补码存放的,这里大家如果不明白的话,可以先去补充一下原码、反码、补码、进制转化的相关知识。
既然相关知识补充的差不多了,那么我们来看一下代码吧!!!
#include解法四: 脑经急转弯int main() { int a, b; while( scanf("%d%d",&a,&b) != EOF ) { a = a^b; b = a^b; a = a^b; printf("%d %dn",a,b); } return 0; }
题目毕竟没有限制我们怎么操作这两个数字,只需要最后的输出结果正确就行,那么我们就可以稍微脑经急转弯一下。
#includeint main() { int a, b; while( scanf("%d%d",&a,&b) != EOF ) { printf("%d %dn",b,a);//(1) } return 0; }
写在最后
- 我们在这里直接先输出b,然后再输出a,那么符合结果。毕竟题目没有做任何限制,所以这种办法也是可行的,不过不太好想到。
该文章内容是我阅读了CSDN博主英雄哪里出来的博文后,自己记录的一些观点和想法,希望对大家有帮助。英雄哪里出来的对应博文地址:传送门



