其他分享
首页 > 其他分享> > 交换两个整数,不使用第三个变量

交换两个整数,不使用第三个变量

作者:互联网

分析:
异或运算,首先必须明确的是异或运算的特点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