C 原地交换两个变量的值

﹏ヽ暗。殇╰゛Y 2022-04-18 03:05 311阅读 0赞

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

如: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

  1. #include<stdio.h>
  2. int swap(int a,int b){
  3. a = a^b;
  4. printf("%d\n",a);
  5. b = a^b;
  6. printf("%d\n",b);
  7. a = a^b;
  8. printf("%d\n",a);
  9. }
  10. int main(){
  11. int a = 2;
  12. int b = 4;
  13. swap(a,b);
  14. }

发表评论

表情:
评论列表 (有 0 条评论,311人围观)

还没有评论,来说两句吧...

相关阅读

    相关 js交换变量

    交换两个变量a,b的值应该怎么做呢?   1.利用临时变量转换。最常规的一种(这是用到的最广泛的一种方式,经实战测试分析,性能也很高)     x=a;    a=b;