返回顶部

异或交换两个变量值

异或交换两个变量值

swap函数完成变量a,b的交换。

void swap(){
	a=a^b;
	b=b^a;
	a=b^a;
}

分析:首先对于异或二进制两数运算结果为:

0^0=0;
0^1=1;
1^0=1;
1^1=0;

异或规律:一个数异或两次另外一个数等于原来那个数,即a ^ b ^ b=a(位置可交换);
由此不难得出:

a=a^b;//第一个a相当于一个中间变量
b=b^a=b^a^b=a;
a=b^a=a^a^b=b;//这里b=a,a=a^b
posted @ 2020-06-28 22:54  #wr  阅读(1048)  评论(0编辑  收藏  举报
         1 2 3