面试题39. 数组中出现次数超过一半的数字

题目

数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。

你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例 1:

输入: [1, 2, 3, 2, 2, 2, 5, 4, 2]
输出: 2

限制:

1 <= 数组长度 <= 50000

注意:本题与主站 169 题相同:https://leetcode-cn.com/problems/majority-element/

解法

采用投票方法,超过半数的票和其他票相抵消的话,最后剩下的一定是超过半数的。

class Solution:
    def majorityElement(self, nums: List[int]) -> int:
        count = 0
        num = nums[0]
        for i in nums:
            if count == 0:
                num = i
                count += 1
            elif i == num: count +=1
            else: count -= 1
        return num

总结

在count为0的时候,不要忘记了num+1.

你可能感兴趣的:(面试题39. 数组中出现次数超过一半的数字)