2018年12月27日
我在写我的第一篇博客,想想还有点小激动呢,第一次写,可能写得不尽如人意,还望大家多多谅解鸭,有什么不正确的地方,还望大家指正。
今天看了一个大佬的代码,发现了一个这样的几行代码:
arr[i]=arr[i]^arr[0];
arr[0]=arr[i]^arr[0];
arr[i]=arr[i]^arr[0];
第一次见到这样的代码,不知道大佬在干什么。然后简单带入几个二进制数化了一下,发现大佬其实是没有借助其他变量就把arr[0]和arr[i]的值给交换了。
好了,进入正题了。
方法一:位运算法
假设开始时:arr[i]=5=0101b,arr[0]=8=1000b.(c语言里int定义的数应该是32位,此处为方便只取4位)
arr[i]=arr[i]^arr[0]=1101b;
arr[0]=arr[i]^arr[0]=0101b=5;
arr[i]=arr[i]^arr[0]=1000b=8;
这样交换完成了。
方法二:算术运算法
int a,b;
a=5,b=6;
a=a+b; //a=11
b=a-b; //b=5
a=a-b; //a=6
就这些了,马上期末了,还要滚回去复习呢。如有错误,还望大家指正鸭。
不借助第三个变量交换两个变量的值的两种方法
最新推荐文章于 2022-12-28 22:44:34 发布