python求众数代码_python-LeetCode-求众数

博客介绍了如何使用Python解决LeetCode中的众数查找问题。通过三种不同的方法:字典计数、排序和摩尔投票法,找到数组中出现次数超过一半的元素。重点讲解了摩尔投票法的高效性和实现细节。
摘要由CSDN通过智能技术生成

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

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

示例 1:

输入: [3,2,3]

输出: 3

示例 2:

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

输出: 2

众数——众数(Mode)是统计学名词,在统计分布上具有明显集中趋势点的数值,代表数据的一般水平(众数可以不存在或多于一个)。 修正定义:是一组数据中出现次数最多的数值,叫众数,有时众数在一组数中有好几个。用 M 表示。 理性理解:简单的说,就是一组数据中占比例最多的那个数。

(来自百度)

我的解法:利用字典,计算每一个数字出现的次数,出现次数最大的那个就是要求的众数,但是根据题目,次数还要大于列表长度的一半,所以有了下面的方法:

class Solution(object):

def majorityElement(self, nums):

"""

:type nums: List[int]

:rtype: int

"""

dict={x:0 for x in nums}

for x in nums:

dict[x]+=1

for x in dict.key():

if dict[x]>len(nums)//2:

return x

这种方法我借鉴了昨天的字典法,利用字典来计数。利用了额外字典空间&#x

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值