异或运算

异或运算

异或,英文为exclusive OR。异或略称为XOR、EOR、EX-OR

异或(xor)是一个数学运算符。它应用于逻辑运算。异或的数学符号为“⊕”,计算机符号为“xor”。

异或也叫半加运算,其运算法则相当于不带进位的二进制加法:二进制下用1表示真,0表示假,则异或的运算法则为:0⊕0=0,1⊕0=1,0⊕1=1,1⊕1=0(同为0,异为1),这些法则与加法是相同的,只是不带进位,所以异或常被认作不进位加法。

  • 按位异或的3个特点:

(1) 00=0,01=1 0异或任何数=任何数

(2) 10=1,11=0 1异或任何数-任何数取反

(3) 任何数异或自己=把自己置0

按位异或的几个常见用途:

  • (1) 使某些特定的位翻转

例如对数100001的第2位和第3位翻转,则可以将该数与000110进行按位异或运算。

100001^000110 = 100111

  • (2)交换
static void swap(){
	a=a^b;
	b=b^a;
	a=a^b;
}
  • (3)快速判断两个值是否相等
    return ((a^b)==0)

  • (4)汇编语言中经常用于将变量置零。
    xor a,a

异或例题

兔子的区间密码

©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页