异或运算学习

1.异或运算运算律:

 2.用异或运算来实现两个地址不同的变量的值的交换

 代码实现:

public class test1 {
    public static void main(String[] args) {
        int a=5;
        int b=10;
        a=a^b;
        b=a^b;
        a=a^b;
        System.out.println("a: "+a+" b: "+b);
    }
}

不建议用这种方法去写交换,会更慢一点。

3.一个数组a[ ]中有两组奇数个的数,n组偶数个的数,用最少内存找出奇数个的数是哪两个。

       假设一个eor=0,让eor去与a[ ]中所有的数去异或,得到的eor就是a^b,a和b就是那两个奇数个的数。eor因为a,b不相同,因此eor的二进制一定有一位为1。因此使eor2=0去异或那个位置为1的所有数,这样就可以得到eor2就是a,b其中一个。再将eor2去异或eor,就可以得到另一个了。

代码实现:

public class test1 {
    public static void main(String[] args) {
        int[] a={1,1,1,2,2,2,3,3,3,3,4,4,4,4};
        int eor=0;
        int eor2=0;
        //得到
        for (int i : a) {
            eor^=i;
        }
        int rightone=eor&(~eor + 1);//提取最右边的1
        for (int i : a) {
            if((i&rightone)==0){
                eor2^=i;
            }
        }
        System.out.println(eor2+" "+(eor^eor2));
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值