原地交换两个变量的值

第一种方法,大家会借助第三个变量来实现:

如:tmp = A; A = B; B = tmp;

这种方法需要借助第三变量来实现;

第二种方法是利用加减法实现两个变量的交换:

如:A = A + B; B = A - B; A = A - B;

但是 如果 A + B 超出 A的范围 ,会引起溢出。

第三种方法是得用位异或运算来实现,也是效率最高的一种,在大量数据交换的时候,效率明显优于前两种方法:

如:A = A ^ B; B = A ^ B; A = A ^ B;

原理:利用一个数异或本身等于0和异或运算符合交换率。

异或的意思就是:不同 才可以得1,否则为0

// 异或
// 0^0=0
// 1^1=0
// 1^0=1
// 0^1=1

    假如 a = 2,b = 4。想将a和b的值互换,可以用一下赋值语句实现:

    a = a ^ b;
    b = b ^ a;
    a = a ^ b;

此方法 完美,推荐使用。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容