当前位置: 首页 > article >正文

异或相关算法

在这里插入图片描述

文章目录

  • 1. 异或的性质
  • 2. 题目一
  • 3. 题目二
  • 4. 题目三
  • 5. 题目四

1. 异或的性质

我们知道,异或的定义是:相同为0,相异为1。所以也被称为无进位相加,根据这定义,我们可以得出三个性质:
1. N ^ N=0。2. N ^ 0=N。3. 异或满足结合律与交换率,所以一组数据,一起异或,结果一定是同一个值

2. 题目一

如何不创建临时变量,交换两个值
答案是:a=a ^ b,b=a ^ b,a=a ^ b

证明:a=a ^ b,a变了,b没变。b=a ^ b,就等于b=a ^ b ^ b,b=a ^ 0,b=a。最后一步,a=a ^ b ^ a,就是a=b ^ 0,a=b。
两个数就进行交换了,但是这个方法只能用在a与b指向不同的内存空间,如果指向同一个内存空间,这样写会把此内存置成0。

3. 题目二

怎么把一个int类型的数,提取出最右侧的1来
什么意思呢?
在这里插入图片描述
就是一个数a,如何得到ans这样的值,就是把最右侧的1提取出来。

答案是:a&(-a)或者a&((~a)+1)这个大家可以自己证明一下。

4. 题目三

一个数组中有两种数出现了奇数次,其它数都出现了偶数次,怎么找到这两个数
解题思路:假设出现两个奇数次的是a和b。
第一步:将数组里的数全部异或,那么结果就是a ^ b,因为其它都是偶数次,异或为0。
第二步:找出a ^ b最右侧的1位置,因为a和b是不同的,所以a ^ b一定不为0,所以a ^ b二进位中一定存在1的。
第三步:a ^ b二进位中的1位置,说明a和b在此位置上是不相等的。我们就把数组中所有此位置为1的分成一组,此位置为0的分成一组。
第四步:将此位置为1的异或在一起就能得出其中一个奇数次,在异或a ^ b,就能得出另外一个奇数次

代码实现:
在这里插入图片描述

5. 题目四

一个数组中有一种数出现K次,其它数都出现了M次,M>1,K<M。找到出现K次的数。要求:时间复杂度O(N),空间复杂度O(1)

解题思路:
第一步:因为一个int类型是32位,所以我们可以先定义一个32的数组。因为是常量数组所以空间复杂度是O(1)。

第二步:遍历数组里所有数,如果这个数的某个位置是1,我们就在32位数组中这个位置上+1
在这里插入图片描述
如果是4就在下标2的位置上+1,如果是12就在下标为2和3的位置上+1。

第三步:遍历这个32位数组,如果某位置上能被M整除,说明出现K次的那个数在此位置上为0,如果此位置不能被M整除,说明此位置上出现K次的那个数此位置为1。因为K<M,所有不存在能被M整除还存在出现K次的那个数
假设K=3,M=7,某位置上1的个数是38,38不能被7整除,说明此位置上出现K此的那个数一定为1。

第四步:定义一个变量为0,如果此位置上不能整除,我们就左移1,然后或上去

代码实现:
在这里插入图片描述


http://www.kler.cn/a/3489.html

相关文章:

  • 当使用 npm 时,出现 `certificate has expired` 错误通常意味着请求的证书已过期。
  • 在elasticsearch中,document数据的写入流程如何?
  • c#配置config文件
  • Android SystemUI——通知栏构建流程(十六)
  • 【前端知识】简单易懂的vue前端页面元素权限控制
  • Linux搭建FTP详细流程
  • [JAVA]一步接一步的一起开发-图书管理系统(非常仔细,你一定能看懂)[1W字+]
  • art 虚拟机相关
  • 不做孔乙己也不做骆驼祥子
  • ESP8266WiFi模块与Android APP实现数据传输(一)---硬件接线
  • 基于 PyTorch + LSTM 进行时间序列预测(附完整源码)
  • 在Linux下常见压缩文件的解压命令:
  • 面试官:rem和vw有什么区别
  • RTL8201 以太网PHY芯片 调试记录
  • 242. 一个简单的整数问题
  • 面试官:vue2和vue3的区别有哪些
  • PMP项目管理-【第一章】引论
  • 番茄学习法——亲测超级好用
  • 分治法实现合并排序(归并排序),理解分治算法思想,实现分治算法的完美例子合并排序(含码源与解析)
  • Householder 变换及其在QR分解中使用的证明
  • Flutter 本地存储 —— 基本的键值对存储
  • 机器学习笔记第四周+知识图谱
  • java中Map遍历的4种方式
  • Hadoop MapReduce知识预览,WordCount词频统计案例
  • 用JS+CSS打造你自己的弹幕王国,让网页动起来!
  • 蓝桥杯刷题冲刺 | 倒计时14天