【LeetCode】多数元素

目录


一、题目

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

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

示例 1:

输入:nums = [3,2,3]

输出:3

示例 2:

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

输出:2

提示:

n == nums.length

1 <= n <= 5 * 104

-109 <= nums[i] <= 109

进阶:尝试设计时间复杂度为 O(n)、空间复杂度为 O(1) 的算法解决此问题。

二、解法

因为多数元素出现次数 大于 ⌊ n/2 ⌋,所以可以使用投票的方法,因为支持自己的元素个数多于一半了,所以可以保证自己一定胜出。

先假定一个元素是多数元素,然后自己支持自己,次数为1,然后继续往后面遍历就行了

每每遍历到一个元素,看一下支不支持自己,支持的话,票数+1,不支持票数-1,投完票之后看看当前投票的对象的票数,如果票数为0了,那么说明暂时没人支持他了,自己就上。重复之前的操作。


完整代码

python 复制代码
class Solution:
    def majorityElement(self, nums: List[int]) -> int:
        res = nums[0]
        cnt = 1
        for i in range(1, len(nums)):
            if res != nums[i]:
                cnt -= 1
            else:
                cnt += 1
            if cnt == 0:
                res = nums[i]
                cnt = 1
        return res
相关推荐
tobias.b3 分钟前
408真题解析-2009-10-数据结构-排序
数据结构·算法·排序算法·408考研·408真题·真题解析
Zachary_zlc7 分钟前
有向无环图检测算法和关键路径算法
算法
你撅嘴真丑8 分钟前
素数回文数的个数 与 求分数序列和
算法
好奇龙猫11 分钟前
【大学院-筆記試験練習:线性代数和数据结构(2)】
数据结构·线性代数·决策树
Wuliwuliii16 分钟前
贡献延迟计算DP
数据结构·c++·算法·动态规划·dp
D_FW17 分钟前
数据结构第一章:绪论
数据结构·考研
ysn1111120 分钟前
简单多边形三角剖分---耳切法(含源码)
算法
e疗AI产品之路21 分钟前
一文介绍Philips DXL心电图算法
算法·pan-tompkins·心电分析
YGGP27 分钟前
【Golang】LeetCode 21. 合并两个有序链表
leetcode·链表·golang
小袁顶风作案30 分钟前
leetcode力扣——135.分发糖果
算法·leetcode·职场和发展