【数据结构和算法实践-位运算-异或-不用额外的变量交换两个数】

位运算-异或-不用额外的变量交换两个数

题目

位运算-异或-不用额外的变量交换两个数

My Thought

int a = A;
int b = B;

  • a=A ^ B;
  • b=a ^ b = A ^ B ^ B = A;
    因为 B ^ B = 0;0 ^ 任意数 = 任意数
  • a= a^b = A ^ B ^ A = b;
    同第二步的原理
    注意:a 和 b 的地址不能一致,不然就^成0了。

代码示例

JAVA-8

   public static void swap(int a, int b,int[] c){
        a = a^b;
        b = a^b;
        a = a^b;
        c[0] = c[1]^c[0];
        c[1] = c[1]^c[0];
        c[0] = c[1]^c[0];
        System.out.println(a+" ."+b+",."+c[0]+".."+c[1]);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值