异或(^)的含义与基本用法

本文介绍了异或(^)运算的含义、性质和在编程中的应用,包括如何利用异或交换两个变量的值,以及解决寻找数组中出现奇数次的数的问题。此外,还探讨了在特定条件下的异或操作策略。
摘要由CSDN通过智能技术生成

异或(^)的含义与基本用法

异或的含义

​ 异或(^)和与运算(&)、或运算(|)都是位运算,因为计算机的运算都是将数据转换成二进制来进行的,所以一般来说,位运算比加减乘除的算数运算快得多。异或的运算法则如下:

1 ^ 0 == 1
1 ^ 1 == 0
0 ^ 0 == 0

相同为0,不同为1

异或的运算性质

​ 异或有几大运算性质:

  • 交换律: ab==ba

  • 结合律: aba==aab

  • 任何非0的数和0异或的结果都是它本身

  • 任何数和自己本身异或的结果都为0

    如果你看到这里,感觉上面列的运算法则和性质有所冲突的时候,请考虑进制不同的情况。本质上异或是在二进制层面上的,这是它的运算法则,当直观表现在十进制上的,才是它的运算性质。

​ 在二进制层面上,异或的运算可以看成是无进位相加,举个例子

	1010110
  	1100011
 ^	0110101

​ 相加的两个二进制数,从右往左数第二位上都是1,1+1本来应该进位1,本位变成0的,然后^运算

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值