【每天学习一点算法 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)

相关推荐
2501_916007472 小时前
从零开始学习iOS开发:Xcode环境配置与项目创建完整指南
ide·vscode·学习·ios·个人开发·xcode·敏捷流程
星幻元宇VR2 小时前
VR动感电动车|以沉浸体验推动交通安全科普新方式
人工智能·科技·学习·安全·生活·vr
云泽8082 小时前
第十五届蓝桥杯大赛软件赛省赛C/C++大学B组
c语言·c++·算法·蓝桥杯
大模型最新论文速读2 小时前
VQKV:KV Cache 压缩 82% 性能几乎不降
人工智能·深度学习·算法·机器学习·自然语言处理
yongui478342 小时前
基于MSP430和Zigbee技术的煤矿综合监控系统设计与实现
算法
Ww.xh2 小时前
ESP8266连接AI大模型完整指南
人工智能·算法·语言模型
程序员雷欧2 小时前
Redis基础知识全解析:从数据结构到生产实战
数据结构·数据库·redis
jiayong233 小时前
第 25 课:给学习笔记页加上搜索、标签筛选和 URL 同步
开发语言·前端·javascript·vue.js·学习
俺不要写代码3 小时前
lambda表达式理解
c++·算法