【每天学习一点算法 2026/04/17】多数元素

每天学习一点算法 2026/04/17

题目:多数元素

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

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

最容易想到的方法就是利用 Map 统计各个元素出现的次数,某一个元素超过 n/2 就返回这个元素。

typescript 复制代码
function majorityElement(nums: number[]): number {
  const map: Map<number, number> = new Map()
  for (let i = 0; i < nums.length; i++) {
    const item = nums[i]
    if (map.has(item)) {
      const count = map.get(item)
      map.set(item, count + 1)
      if (count + 1 > nums.length / 2) {
        return item
      }
    } else {
      map.set(item, 1)
      if (nums.length === 1) {
        return item
      }
    }
  }
};

我们还可以对数组进行排序那么位于中间的元素一定是众数

typescript 复制代码
function majorityElement(nums: number[]): number {
  return nums.sort()[Math.floor(nums.length / 2)]
};

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

Boyer-Moore 投票算法

我们遍历数组元素进行两两对比,遇到不同的元素就消耗掉它们,到最后剩下的一定就是众数,因为最差的情况也只能消耗 n / 2 个众。具体实现方法需要维护两个变量,一个是当前候选的众数以及它出现的次数,当次数归零就需要更换候选众数。

typescript 复制代码
function majorityElement(nums: number[]): number {
  let res = nums[0], count = 1 // 初始化候选众数和它出现的次数
  // 遍历消耗元素
  for (let i = 1; i < nums.length; i++) {
    if (nums[i] === res) {
      // 遇到相同元素 数量 + 1
      count++
    } else {
      // 遇到不同元素 数量 - 1
      count--
      if (count === 0) {
        // 如果数量归 0 更换候选众数为下一个元素
        res = nums[i + 1]
      }
    }
    
  }
  return res
};

题目来源:力扣(LeetCode)

相关推荐
多加点辣也没关系18 小时前
数据结构与算法|第十三章:递归与分治
数据结构·算法
陌路2018 小时前
第一行代码--初步学习--Android四大组件-activity1
android·学习
梦梦代码精18 小时前
LikeShop 是否安全可靠?——从架构设计到数据表现的系统性分析
数据结构·团队开发·安全性测试
m0_6294947318 小时前
LeetCode 热题 100-----21.搜索二维矩阵 II
数据结构·算法·leetcode
平行侠19 小时前
018二进制GCD(Stein算法)- 用位运算代替除法的最大公因数
数据结构·算法
月疯19 小时前
卡尔曼滤波的数学计算流程
算法
黎阳之光19 小时前
黎阳之光:深耕视频孪生核心领域 构筑数字孪生全域数智新标杆
大数据·人工智能·算法·安全·数字孪生
sbjdhjd19 小时前
2026年第十七届蓝桥杯大赛软件赛省赛 Python 大学 B 组 A-F 题 完整题解(小白友好版)
python·算法·职场和发展·蓝桥杯·pycharm·开源·动态规划
nlpming19 小时前
Superpowers 项目全面解析
算法
无限进步_19 小时前
【C++】红黑树完全解析:从概念到插入与平衡维护
java·c语言·开发语言·数据结构·c++·后端·算法