一、题目描述
给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在多数元素。
二、解题思路过程
class Solution:
def majorityElement(self, nums: List[int]) -> int:
# 摩尔投票法
major=0
count=0
for i in range(0,len(nums)):
if count==0 or nums[i]==major: # 若 count == 0,代表当前 major 空缺,直接将当前候选人赋值给 major,并令 count+1
major=nums[i]
count+=1
else: # 若 count != 0,代表当前 major 的票数未被完全抵消,因此令 count--,即使用当前候选人的票数抵消 major 的票数
count-=1
return major
三、复杂度分析
时间复杂度:,仅遍历一次数组。
空间复杂度:,没有使用额外空间。
四、题目来源
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/majority-element