【码道初阶】一道经典的简单题:Boyer-Moore 多数投票算法|多数元素问题(LeetCode 169)

多数元素问题是算法题中的经典题型:给定一个长度为 n 的数组,其中一个元素出现次数 大于 n/2,需要在线性时间、常数空间内找出它。

例:

复制代码
输入: [2,2,1,1,1,2,2]
输出: 2

题目保证多数元素一定存在。


核心思想:成对抵消,剩者为王

如果一个元素的出现次数超过一半,那么在与其它所有元素进行"成对抵消"后,它必然能够存活下来。

Boyer--Moore 投票算法正是基于这个思想:

  • 遍历数组时维护两个量:

    • candidate:当前候选人

    • count:候选人的净票数

对每个数字 num

  1. count == 0,将候选人设为 num

  2. num == candidatecount++(支持票)。

  3. 否则 count--(反对票,抵消一张支持)。

因为多数元素的票多于其它所有元素的总和,因此不可能被完全抵消,最终留下的 candidate 就是多数元素。


Java 代码(O(n) 时间 + O(1) 空间)

复制代码
class Solution {
    public int majorityElement(int[] nums) {
        int candidate = 0;
        int count = 0;

        for (int num : nums) {
            if (count == 0) {
                candidate = num;
                count = 1;
            } else if (num == candidate) {
                count++;
            } else {
                count--;
            }
        }

        return candidate;
    }
}

为什么算法有效?

把数组看作"选举":

  • 多数元素拥有超过半数的票,无法被其它元素完全抵消。

  • 抵消完所有成对元素后,剩下的一定就是多数元素。

整个过程只需一次遍历(线性时间),并且使用常量额外空间,非常高效。


总结

多数投票算法是一种优雅且高效的线性时间算法:

  • 时间复杂度:O(n)

  • 空间复杂度:O(1)

  • 适用条件:多数元素保证存在

这是算法面试中极其常见的模板技巧,与"异或消对法"(如 LeetCode 136)一起,是必备基础工具。

如果你理解了"成对抵消、剩者为王"的直觉,这道题就再也不会忘记。

相关推荐
智者知已应修善业4 小时前
【51单片机LED闪烁10次数码管显示0-9】2023-12-14
c++·经验分享·笔记·算法·51单片机
智者知已应修善业4 小时前
【51单片机2按键控制1个敞亮LED灯闪烁和熄灭】2023-11-3
c++·经验分享·笔记·算法·51单片机
AI算法沐枫4 小时前
大模型 | 大模型之机器学习基本理论
人工智能·python·神经网络·学习·算法·机器学习·计算机视觉
吃着火锅x唱着歌4 小时前
LeetCode 1019.链表中的下一个更大节点
算法·leetcode·链表
凌波粒5 小时前
LeetCode--404.左叶子之和(二叉树)
算法·leetcode·职场和发展
paeamecium5 小时前
【PAT甲级真题】- A+B in Hogwarts
c++·算法·pat考试·pat
青山师5 小时前
二叉树与BST深度解析:遍历算法与平衡策略
数据结构·算法·面试·二叉树·算法与数据结构·java面试·数据结构与算法分析
绝知此事5 小时前
【算法突围 03】核心算法思想:分治/递归/动态规划与 LeetCode 高频真题解析
算法·leetcode·面试·动态规划
AI科技星5 小时前
第二章 平行素数对网格:矩形→等腰梯形拓扑变换(完整公理终稿)
c语言·开发语言·线性代数·算法·量子计算·agi