LeetCode 热题100-97 多数元素

多数元素

给定一个大小为 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) 的算法解决此问题。

这个题目最先想到的是hashmap,直接遍历统计就好,然后找出来,但是这样时间复杂是o(n),空间复杂也是o(n);达不到进阶的要求...qwq

python 复制代码
class Solution:
    def majorityElement(self, nums: List[int]) -> int:
        hashmap = {}
        for i in nums:hashmap[i] = 1 if i not in hashmap else hashmap[i]+1
        for i,v in hashmap.items():
            if v>=len(nums)//2+1:return i

然后看了看k大佬的解析,发现其实还能用数组排序来做,数组中间的数一定是最后的多数元素

另外进阶的方法应该是 摩尔投票的方法 用一个vote来标志当前考察元素的票数,然后如果一样的话则vote+1,否则-1.这样当vote=-1的时候说明考察元素需要更换了,以此类推下去即可找到最多的那个多数元素

python 复制代码
class Solution:
    def majorityElement(self, nums: List[int]) -> int:
        vote = 0
        idx = 0
        res = nums[idx]
        while idx<len(nums):
            vote = vote + 1 if res == nums[idx] else vote - 1
            if vote == -1:
                res = nums[idx]
                vote = 1
            idx+=1
        return res
相关推荐
Mr_Xuhhh1 分钟前
深入理解单链表的递归反转:从原理到实现
算法·leetcode·职场和发展
海寻山5 分钟前
Java 泛型 (Generic) 入门到精通:语法 + 原理 + 实战 + 避坑
java·windows·python
智者知已应修善业5 分钟前
【51单片机数码管+蜂鸣器的使用】2023-6-14
c++·经验分享·笔记·算法·51单片机
2301_803538956 分钟前
SQL如何避免不同团队修改同一张表_基于前缀名的授权GRANT ON语法
jvm·数据库·python
m0_6784854512 分钟前
c++怎么在Windows下设置文件的安全访问控制列表(ACL)权限【底层】
jvm·数据库·python
迷途之人不知返13 分钟前
算法类型:双指针类型
算法
2301_8176722617 分钟前
Go语言怎么做六边形架构_Go语言六边形架构教程【简明】
jvm·数据库·python
吴可可12317 分钟前
三点绘圆弧的几何实现
算法
Dshuishui17 分钟前
学习一下 Python 包管理器 uv
开发语言·python·uv
kyle~20 分钟前
导航---LIO(激光雷达-惯性里程计)算法
c++·算法·机器人·ros2·导航