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