如何不适用任何额外空间,交换两个数的值

在初接触编程的时候大家都知道要交换两个变量的值,必须要使用一个新的变量来作为中间变量。今天在看操作系统的时候发现了原来还可以不使用中间变量一样可以交换两个数的值。代码如下:

#include<stdio.h>
void swap(int *a , int *b){
    *a = *a ^ *b;
    *b = *a ^ *b;
    *a = *a ^ *b;
}
int main(){

    int a = 3,b = 4;
    swap(&a,&b);
    printf("%d %d",a,b);

}

这个不使用中间变量交换两个数的值的方法中使用了异或这个为运算,我们都知道一个数异或上他的本身就会把每一位置零。在上面的交换两个数的函数中,首先将a和b异或并将得到的值赋给a,此时的a的值就是a^b,记做a1。然后将此时的a1和b进行异或再将值赋给b。

b = a1 ^ b;
b = a ^ b ^b;
b = a ^ 0;
任意数异或上0都会得到本身
b = a;

此时的b的值已将变成了a,我们将此时的b记做b1。最后将得到的b1再和a1异或,将值赋给a

a1 = a1 ^ b1;
a1 = a ^ b ^ a;
a1 = b;

最终a和b没有使用任何的额外变量就完成了两个数的交换。
emmm最后说一点,这里只是表面上的没有使用任何的额外空间。但是用于在这个地方额外使用了三次异或运算。所以在时间上有可能会比使用中间变量来进行交换会慢一些。还没有进行测试所以此时还没有准确的数据。后面进行了测试再更新

#include<stdio.h>
void swap(int *a , int *b){
    *a = *a ^ *b;
    *b = *a ^ *b;
    *a = *a ^ *b;
}
int main(){

    int a = 3,b = 4;
    int count = 10000000;
    while(count--)
    swap(&a,&b);


}

这是使用异或运算的交换时间

#include<stdio.h>
void swap(int *a , int *b){
  int temp = *a;
        *a = *b;
        *b = temp;
}
int main(){

    int a = 3,b = 4;
    int count = 10000000;
    while(count--)
    swap(&a,&b);


}

这是使用中间变量的交换时间
使用异或运算来交换两个数的值,从实验结果来看并没有对性能有任何优化,甚至还对性能有一定坏的影响。所以还是安心用中间变量来交换两个数的值吧。除非是有的编程对于空间的要求十分严格的时候,才会用到这个异或来交换两个数的值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值