交换两个整数,不使用第三个变量
作者:互联网
分析:
异或运算,首先必须明确的是异或运算的特点a ^ b=c, a ^ c = b,b ^ c = a,任意两个进行异或得到的第三个数,第三个数和自身异或即可得到另一个数。根据这个特点,适用的场景就多了,比如本文的交换两个数、加密与解密等,特点就是高效,异或运算,移位运算其性能远远高于普通的加减乘除,这个可以自己去验证。提示:根据运算的次数能够大致估算出哪个更快。
#include<iostream>
using namespace std
//交换两个变量的值,不使用第三个变量
int main()
{
int a = 12;
int b = 23;
cout << "交换前的两个数为:";
cout << "a=" << a << " b=" << b << endl;
cout << "交换后的两个数为:";
//因为不能使用第三个变量,也不能将异或的值,如果保存给当前的a或b,那么a或b的值只有一个可以发生变化,再异或下一个就不行了
cout << "a=" << ((a ^ b) ^ a) << " b=" << ((a ^ b) ^ b) << endl;
return 0;
}
运行结果:
标签:运算,int,交换,整数,异或,第三个,变量 来源: https://blog.csdn.net/qq_41765969/article/details/113781067