QQ登录

只需一步,快速开始

手机号码,快捷登录

手机号码,快捷登录

查看: 485|回复: 0
收起左侧

程序员小灰-漫画算法:找出缺失的整数

[复制链接]
发表于 2018-10-8 11:44:44 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册加入

×
来源:程序员小灰


y9KYU99g2ru294r4.jpg



yQ3ih3Ib5OUi635B.jpg



xeyJmYM8Ip8MazP9.jpg



YZFtjkqRA1FcBBjC.jpg





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



O99Mc9ZQ89Q1P82V.jpg





I25UZutktGFbUGuB.jpg



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





V6zy4Bpo7M7ojOjj.jpg



解法一:
创建一个HashMap,以1到100为键,值都是0 。然后遍历整个数组,每读到一个整数,就找到HashMap当中对应的键,让其值加一。
由于数组中缺少一个整数,最终一定有99个键值等于1, 剩下一个键值等于0。遍历修改后的HashMap,找到这个值为0的键。
假设数组长度是N,那么该解法的时间复杂度是O(1),空间复杂度是O(N)。


KYfZ7SV2SifeNEYA.jpg



J0PXLLHhHDPX8Vvp.jpg



Y93xZ5TS6Epx39Bp.jpg





解法二:
先把数组元素进行排序,然后遍历数组,要么有其中两个相邻元素之间的差不是1,要么缺失的整数是1或100。
假设数组长度是N,如果用时间复杂度为O(N*LogN)的排序算法进行排序,那么该解法的时间复杂度是O(N*LogN),空间复杂度是O(1)。


tzqhssEKV8EDpb1p.jpg



cLMdT65zgSS3rttR.jpg



o66n8vCmB6nN7G9Z.jpg



解法三:
很简单也很高效的方法,先算出1+2+3....+100的合,然后依次减去数组里的元素,最后得到的差,就是唯一缺失的整数。
假设数组长度是N,那么该解法的时间复杂度是O(N),空间复杂度是O(1)。


T4WkPBAYR8aAHaYq.jpg



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


jjjKSvsc3sK0Jql7.jpg



wqd0vZwue34vRI3N.jpg







KXvGEjIysGVwemeT.jpg







M88RzcKhFY8vzcoR.jpg



e0s6F6b00PFzFuDJ.jpg



解法:
遍历整个数组,依次做异或运算。由于异或在位运算时相同为0,不同为1,因此所有出现偶数次的整数都会相互抵消变成0,只有唯一出现奇数次的整数会被留下。
假设数组长度是N,那么该解法的时间复杂度是O(N),空间复杂度是O(1)。


CfdFZvooDjFY39YO.jpg



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


BiuitUGgZuiui2uh.jpg





WxPwtcTtTttP5gtB.jpg





oieiekitv5aicrCK.jpg







CaPbX76tD9wi7vax.jpg



解法:
遍历整个数组,依次做异或运算。由于数组存在两个出现奇数次的整数,所以最终异或的结果,等同于这两个整数的异或结果。这个结果中,至少会有一个二进制位是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)。


X1GGpEs3GgjW8Wyw.jpg



十分钟后......
u4JwuxDt1D0ZrITI.jpg



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



NSSS2V20xvQ82D2y.jpg



d99k92282LG4lp2w.jpg



YumccrMRRUvcz202.jpg
欢迎来到【天府同城大成都】-天府四川的吃喝玩乐—生活消费媒体网站!请记住我们的域名www.fqtc.com
您需要登录后才可以回帖 登录 | 注册加入

本版积分规则

×本站发帖友情提示
1、注册用户在本站发表/转载的任何作品仅代表其个人观点,不代表本站立场。
2、如果存在违反国家相关法律、法规、条例的行为,我们有权在不经作者准许的情况下删除其在本站所发表的文章。
3、所有网友不要盗用有明确版权要求的作品,转贴请注明来源,否则文责自负。如有侵犯您的权益请联系我们及时删除。
4、本站保护注册用户个人资料,但是在自身原因导致个人资料泄露、丢失、被盗或篡改,本站概不负责,也不承担相应法律责任。

关闭

站长推荐上一条 /1 下一条

客服热线
400-1234-888 周一至周日:09:00 - 21:00
公司地址:北京市朝阳区科技路88号现代城5号楼

天府生活网(www.fqtc.com)四川生活网为你提供房产、招聘、黄页、团购、交友、二手、宠物、车辆、周边游、本地生活、供求信息等海量分类信息,是专业,免费,高效的本地生活信息服务平台。

Powered by Discuz! X3.5 © 2001-2013 Comsenz Inc.

QQ|广告报价|小黑屋|Archiver|手机版|免责声明|大成都 ( 蜀ICP备19006310号-4 )

GMT+8, 2024-11-27 10:41 , Processed in 0.113535 second(s), 23 queries .

快速回复 返回顶部 返回列表