leetcode 169. 多数元素

给定一个大小为 的数组,找到其中的多数元素。多数元素是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素。

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


示例 1:

输入: [3,2,3]
输出: 3

示例 2:

输入: [2,2,1,1,1,2,2]
输出: 2

哈希表:

class Solution(object):
    def majorityElement(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        dic = {}
        val = int(len(nums)/2)
        for num in nums:
            if num not in dic:
                dic[num] = 1
            else:
                dic[num] += 1
            if dic[num] > val:
                return num
        return None

最简单的可以使用哈希表,在遍历时如果数字不存在于哈希表,则将值计为1,否则就加1,作为计数器。并且在完毕之后判断是否该数字出现的频率已经超出了设定值,如果超出就返回该值表示找到该多数元素。该方法时间复杂度为O(n),空间复杂度也为O(n)。

摩尔投票法:

class Solution(object):
    def majorityElement(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        major = 0
        count = 0
        
        for n in nums:
            if count == 0:
                major = n
            if n == major:
                count = count + 1
            else:
                count = count - 1

        return major

由于题目要求出现次数大于n/2的元素,说明该元素为集合的众数且比例超过一半。所以此时可以巧妙地使用摩尔投票法。

我们遍历投票数组,将当前票数最多的候选人与其获得的(抵消后)票数分别存储在 major 与 count 中。

当我们遍历下一个选票时,判断当前 count 是否为零:

  • 若 count == 0,代表当前 major 空缺,直接将当前候选人赋值给 major,并令 count++
  • 若 count != 0,代表当前 major 的票数未被完全抵消,因此令 count--,即使用当前候选人的票数抵消 major 的票数

由于该元素出现频率过半,那么这个可以粗略理解为一个特别的计数器,遍历数组时当出现的是该元素时计数器加一,否则减一。那么最终的count必然大于0,且major就为所要求的多数元素。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值