转载自 玻璃猫 程序员小灰

小灰一边回忆一边讲述起当时面试的情景......

题目:一个无序数组里有99个不重复正整数,范围从1到100,唯独缺少一个整数。如何找出这个缺失的整数?

解法一:

创建一个HashMap,以1到100为键,值都是0 。然后遍历整个数组,每读到一个整数,就找到HashMap当中对应的键,让其值加一。

由于数组中缺少一个整数,最终一定有99个键值等于1, 剩下一个键值等于0。遍历修改后的HashMap,找到这个值为0的键。

假设数组长度是N,那么该解法的时间复杂度是O(1),空间复杂度是O(N)。

解法二:

先把数组元素进行排序,然后遍历数组,要么有其中两个相邻元素之间的差不是1,要么缺失的整数是1或100。

假设数组长度是N,如果用时间复杂度为O(N*LogN)的排序算法进行排序,那么该解法的时间复杂度是O(N*LogN),空间复杂度是O(1)。

解法三:

很简单也很高效的方法,先算出1+2+3....+100的合,然后依次减去数组里的元素,最后得到的差,就是唯一缺失的整数。

假设数组长度是N,那么该解法的时间复杂度是O(N),空间复杂度是O(1)。

题目扩展:一个无序数组里有若干个正整数,范围从1到100,其中99个整数都出现了偶数次,只有一个整数出现了奇数次(比如1,1,2,2,3,3,4,5,5),如何找到这个出现奇数次的整数?

解法:

遍历整个数组,依次做异或运算。由于异或在位运算时相同为0,不同为1,因此所有出现偶数次的整数都会相互抵消变成0,只有唯一出现奇数次的整数会被留下。

假设数组长度是N,那么该解法的时间复杂度是O(N),空间复杂度是O(1)。


题目第二次扩展:一个无序数组里有若干个正整数,范围从1到100,其中98个整数都出现了偶数次,只有两个整数出现了奇数次(比如1,1,2,2,3,4,5,5),如何找到这个出现奇数次的整数?

解法:

遍历整个数组,依次做异或运算。由于数组存在两个出现奇数次的整数,所以最终异或的结果,等同于这两个整数的异或结果。这个结果中,至少会有一个二进制位是1(如果都是0,说明两个数相等,和题目不符)。

举个例子,如果最终异或的结果是5,转换成二进制是00000101。此时我们可以选择任意一个是1的二进制位来分析,比如末位。把两个奇数次出现的整数命名为A和B,如果末位是1,说明A和B转为二进制的末位不同,必定其中一个整数的末位是1,另一个整数的末位是0。

根据这个结论,我们可以把原数组按照二进制的末位不同,分成两部分,一部分的末位是1,一部分的末位是0。由于A和B的末位不同,所以A在其中一部分,B在其中一部分,绝不会出现A和B在同一部分,另一部分没有的情况。

这样一来就简单了,我们的问题又回归到了上一题的情况,按照原先的异或解法,从每一部分中找出唯一的奇数次整数即可。

假设数组长度是N,那么该解法的时间复杂度是O(N)。把数组分成两部分,并不需要借助额外存储空间,完全可以在按二进制位分组的同时来做异或运算,所以空间复杂度仍然是O(1)。

十分钟后......

以上就是小灰面试的情况......

漫画算法:找出缺失的整数相关推荐

  1. 程序员面试金典——5.7找出缺失的整数

    程序员面试金典--5.7找出缺失的整数 参考网址:https://www.nowcoder.com/profile/8185333/codeBookDetail?submissionId=125997 ...

  2. 现在有一个整数数组,已知一个数出现的次数超过了一半,请用O(n)的复杂度的算法找出这个数...

    现在有一个整数数组,已知一个数出现的次数超过了一半,请用O(n)的复杂度的算法找出这个数. 方法1:Hash链表 方法2:使用两个变量A和B,其中A存储某个数组中的数,B用来计数.开始时将B初始化为0 ...

  3. Java中找出缺失的数字

    给定一组连续的整数,例如:10,11,12,--,20,但其中缺失一个数字,试找出缺失的数字1 import java.util.*;2 3 public class Main {4 public s ...

  4. LeetCode 2028. 找出缺失的观测数据

    文章目录 一.题目 1.题目描述 2.基础框架 3.原题链接 二.解题报告 1.思路分析 2.时间复杂度 3.代码详解 三.本题小知识 四.加群须知 一.题目 1.题目描述   现有一份 n + m次 ...

  5. 知哈希算法——找出相似的图片

    知哈希算法--找出相似的图片 感知哈希算法--找出相似的图片 - Create Chen - 博客园 知哈希算法--找出相似的图片 Google 图片搜索功能 在谷歌图片搜索中, 用户可以上传一张图片 ...

  6. 【算法分析与设计】找出缺失的一个整数问题

    问题描述 对于1-100之间的数,给出一个不重复的.数据总数99的无序序列,设计算法求解缺的一个数值. 本题可以可扩展成从1-N+1之间不重复的N个数组成的序列找出缺的数据. 分析 有三种算法思路,下 ...

  7. 找出N个整数中最大的K个数

    原文来自:博客园(华夏35度)http://www.cnblogs.com/zhangchaoyang 作者:Orisun 如题:给出N个整数(N可能很大,以致无法装入内存),找出前K个最大的整数 [ ...

  8. c语言 判断互质,[经典算法] 找出某数以内与其互质的数

    起因:前几天做了一个这样的题目,感觉自己变成了一个智障,来写写算法: 相关定义: ①质数定义:没有除 '1' 以外的因子的数就是质数.如:1.3.5.7.11等等. ②互质定义:两个数之间除 '1'  ...

  9. Apriori算法找出频繁项集(python)

    目标 数据库有5个事务.设min_sup=60%,min_conf=80%. TID 购买的商品 T100 {M,O,N,K,E,Y} T200 {D,O,N,K,E,Y} T300 {M,A,K,E ...

最新文章

  1. 虚拟机系统如何添加硬件?
  2. python判断文件是否为空文件对象_判断Python对象是不是为文件对象的方法有哪些...
  3. python爬虫之urllib库详解
  4. HDU4633(Polya计数)
  5. ACE在AIX环境下编译指南
  6. UIview需要知道的一些事情:setNeedsDisplay、setNeedsLayout
  7. 【js实例】Array类型的9个数组方法,Date类型的41个日期方法,Function类型
  8. 【pyqt5】 读取numpy arrray 显示图片
  9. 根据location地址,在导航栏高亮显示当前页面
  10. Tomcat 报 The valid characters are defined in RFC 7230 and RFC 3986
  11. 合并数据 - 方法总结(concat、append、merge、join、combine_first)- Python代码
  12. C ++ 指针 | 指针与字符_4
  13. VMware虚拟机关闭后托盘运行设置
  14. OpenJudge 8782 乘积最大——S.B.S
  15. python学到什么程度可以找到工作-月薪2万+的Python Web岗,学到什么程度能找到工作?...
  16. 关于SpringBoot和Thymeleaf模板中遇到的问题
  17. 190505每日一句
  18. php和composer关系_使用Composer管理PHP依赖关系
  19. Nature命名规范
  20. Elasticsearch 拼音分词器

热门文章

  1. [JavaWeb-XML]XML组成部分
  2. [PAT乙级]1016 部分A+B
  3. flutter图片预览_flutter好用的轮子推荐四-可定制的图片预览查看器photo
  4. 使用Java查询Sql Server数据库
  5. RNN循环神经网络概述
  6. P3345 [ZJOI2015]幻想乡战略游戏
  7. P6154 游走 概率dp
  8. P1850 [NOIP2016 提高组] 换教室
  9. 牛客题霸 [判断一个链表是否为回文结构] C++题解/答案
  10. 牛客网 【每日一题】7月24日题目精讲—小A的柱状图