blog/source/_posts/2020-03-23-leetcode-169.md
Ching 9690121403 feat(init project): add all existing files
add all existing files

Signed-off-by: Ching <loooching@gmail.com>
2022-02-02 19:04:18 +08:00

1.6 KiB
Raw Permalink Blame History

title date tags categories
leetcode-169 2020-03-23 23:12:57 leetcode

169. 多数元素

题目

一开始的思路是遍历一遍整个列表,用一个字典去记录每个元素出现的次数,当次数大于 \cfrac{n}{2} 时就可以得出结果。

class Solution:
  def majorityElement(self, nums) -> int:
    d = {}
    l = len(nums)
    for n in nums:
      if not n in d:
        d[n] = 0
      d[n] = d[n] + 1
      if d[n] > l/2:
        return n
# 64 ms	15.1 MB

Python 也有专门计数的库,写起来更简单一点:

class Solution:
  def majorityElement(self, nums):
    counts = collections.Counter(nums)
      return max(counts.keys(), key=counts.get)
# 44 ms	15.1 MB

由于要找的数出现次数大于 $\cfrac{n}{2}$,脑子里掠过一下蒙特卡罗算法,后来在官方解答中也看到类似的思路了:

class Solution:
    def majorityElement(self, nums):
        majority_count = len(nums)//2
        while True:
            candidate = random.choice(nums)
            if sum(1 for elem in nums if elem == candidate) > majority_count:
                return candidate

#作者LeetCode-Solution
#链接https://leetcode-cn.com/problems/majority-element/solution/duo-shu-yuan-su-by-leetcode-solution/
#来源力扣LeetCode
#著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。