1 基本概念
1.1 符号
异或是一种二进制的位运算,符号以 XOR 或 ^ 表示。
1.2 运算规则
相同为0,不同为1,即
1 ^ 1 = 0
0 ^ 0 = 0
1 ^ 0 = 1
由运算规则可知,任何二进制数与零异或,都会等于其本身,即 A ^ 0 = A,0^A=A。
1.3 异或性质
(1)交换律: A ^ B = B ^ A
(2)结合律: ( A ^ B ) ^ C = A ^ ( B ^ C )
(3)自反性: A ^ B ^ B = A (由结合律可推: A ^ B ^ B = A ^ ( B ^ B ) = A ^ 0 = A)
2 异或应用
2.1 变量交换
int a,b;
a=6;
b=4;
a=a^b;
cout<<"a="<<a<<endl;
b=a^b;
cout<<"b="<<b<<endl;
a=a^b;
cout<<"a="<<a<<endl;
2.2 排除偶次重复
int a[11]={1,2,3,4,5,6,1,2,3,5,6};
int i;
int b=0;
for(i=0;i<11;i++)
{
b=a[i]^b;
}
cout<<b;
2.3 排除偶次重复变种
找出数组中出现两次的数字
int a[6];
int i;
for(i=0;i<5;i++)
{
a[i]=i+1;
}
a[5]=1;
int b=0;
for(i=0;i<6;i++)
{
b=a[i]^b;
}
for(i=0;i<5;i++)
{
b=b^(i+1);
}
cout<<b;
1666

被折叠的 条评论
为什么被折叠?



