美文网首页
算法:找出正确的整数

算法:找出正确的整数

作者: Caolongs | 来源:发表于2017-12-14 10:05 被阅读18次

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

解法一:
创建一个HashMap,以1到100为键,值都是0.然后遍历整个数组,每读到一个整数,就找到HashMap当中对应的键,让其加一。
由于数组中缺少一个整数,最终一定有99个键对应的值等于1,剩下一个键对应的值等于0。遍历修改后的HashMap,找到这个值为0的键。

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

解法二:
先把数组元素进行排序,然后遍历数组,检查任意两个相邻元素数值是否连续。如果不连续,则中间缺少的的整数就是所要寻找的;如果全部连续,则缺少的整数不是1就是100.

假设数组长度是N,时间复杂度为O(N*LogN)(排序算法),空间复杂度是O(1)。

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

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


题目扩展:

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

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

相关文章

  • 算法:找出正确的整数

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

  • 漫画算法:找出缺失的整数

    小灰一边回忆一边讲述起当时面试的情景...... 题目:一个无序数组里有99个不重复正整数,范围从1到100,唯独...

  • 缺失的第一个正数

    给定一个未排序的整数数组,找出其中没有出现的最小的正整数。 示例 1: 示例 2: 示例 3: 说明: 你的算法的...

  • LeetCode 41. 缺失的第一个正数

    题目 给你一个未排序的整数数组,请你找出其中没有出现的最小的正整数。 提示: 你的算法的时间复杂度应为O(n),并...

  • LeetCode-python 128.最长连续序列

    题目链接难度:困难 类型: 哈希 给定一个未排序的整数数组,找出最长连续序列的长度。 要求算法...

  • 数据结构与算法-链表相关题

    数据结构预算法题 正确的解算法题,前提是要正确审题,找出关键词! 题⽬1 : 将2个递增的有序链表合并为⼀个链表的...

  • 《算法4第一章》笔记(三)2-sum(2)

    问题说明: 从一组数据中找出所有和为0的整数对的数量。(所有整数均各不相同) 这次使用二分查找来优化算法 源码: ...

  • 《算法4第一章》笔记(五)3-sum(2)

    问题说明: 从一组数据中找出所有和为0的整数对的数量。(所有整数均各不相同) 这次使用二分查找来优化算法 源码: ...

  • BFPRT 算法

    本节以今天leetcode打卡题为例来介绍下BFPRT算法。 最小的k个数 输入整数数组 arr ,找出其中最小的...

  • 【第二周】3.找出数组中未出现的最小正整数

    【问题描述】给定一个含n(n≥1)个整数的数组,请设计一个在时间上尽可能高效的算法,找出数组中未出现的最小正整数。...

网友评论

      本文标题:算法:找出正确的整数

      本文链接:https://www.haomeiwen.com/subject/cmnmbxtx.html