异或运算交换两个数的值

简介: 异或运算交换两个数的值

交换两个数的值(利用两个数的和,再做减法交换两个数)

a=5.b=10

a=a+b 此时a=15

b=a-b 此时b=10

a=a-b 此时a=5

开始把式子写成了a=a+b-a,后面写不下去了,一直思考为什么要有a=a+b 这个步骤,其实a=a+b-a推出来就是a=b,也就是把b的值直接赋值给a,后面当然没法做了,这是内存,值是会覆盖的。题目的解题思路就是利用两个数的和,所以必要要有第一步,接着后面的逻辑就清楚了。

交换两个数的值通常就都是创建一个临时变量,还有一种是利用的二进制,异或运算。

异或运算两种理解:

一种是相同为0,不同为1,

另一个角度是:

当左边的数为0时,其结果就和右边的数一样

当左边的数为1时,其结果就和右边的数取反

所以a ^ b就是:

左边的a,如果位数为0,表示原值a和b的这个位数是一样的,那么b的这个位数就不需要改

左边的a,如果位数为1,表示原值a和b的这个位数是不一样的,那么b的这个位数就需要取反。


后面还没有想的很清楚,还要再思考,等待后续。。


相关文章
|
6天前
|
存储 算法 JavaScript
判断奇偶数
判断奇偶数
|
7月前
|
算法
把数组里面数值排成最小的数
把数组里面数值排成最小的数
21 1
|
7月前
交换两个数的值的方法(三种)
交换两个数的值的方法(三种)
37 1
|
9月前
不使用第三变量。如何对2个数进行交换
不使用第三变量。如何对2个数进行交换
54 0
|
11月前
判断数的奇偶性
判断数的奇偶性
52 0
判断一个数是否是对称数(数组/非数组解法)
判断一个数是否是对称数(数组/非数组解法)
|
12月前
求一个数的二进制位中1的个数
求一个数的二进制位中1的个数
|
算法
算法练习——(1)找数组中唯一成对的那个数(异或)
——如何找数组中唯一成对的那个数(数组特殊) 1-1000这一千个数放在含有1001个元素的数组中,只有唯一的一个元素值重复,其他均只出现一次。 每个数组元素只能访问一次,设计一个算法,将他找出来;不用辅助储存空间,设计一个算法实现.
|
机器学习/深度学习
【每日一题Day84】LC2283判断一个数的数字计数是否等于数位的值 | 哈希表
思路:使用哈希表统计每个数字出现的次数,再与字符串中的次数进行比较,如果所有数字次数均等于字符串中的次数,返回true;反之,返回false
46 0
03:奇偶数判断
03:奇偶数判断
92 0