JavaScript版《剑指offer》刷题(27)
1.题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。 2.题目分析 思路一:暴力枚举 先排序,然后找出中间的值,复杂的O(nlogn) 思路二:利用O(n)的空间,换取时间复杂度O(n) 基于快排思想中的partition函数来做,因为根据题目,那么排序后的数组中间的数就是那个出现次数超过一半的数,那么我只需要利用快排中的partition,找到长度为n的数组中间n/2大的那个数就行。 我们有成熟的时间复杂度为的算法得到数组中任意第k大的数字。只不过现在的K值为数组长度的一半。 思路三:利用这个数组的特性,保存两个值,一个是数组中的数字,另一个是次数。 根据数组特点来做,数组中有一个数字出现的次数超过数组长度的一半,也就是说它出现的次数比其他所有数字出现的次数的和还要多。因此,我们可以考虑在遍历数组的时候保存两个值:一个是数组中的一个数字;一个是次数。当我们便利到下一个数字的时候,如果下一个数字和我们之前保存的数字相同,则次数加1;如果下一个数字和我们之前保存的数字不同,则次数减1.如果次数为零,那我们需要保存下一个数字,并把次数设为1.由于我们要找的数字出现的次数比其他所有数字出现次数之和还要多