Boyer-Moore 投票算法

算法概述

Boyer-Moore 投票算法用于高效寻找数组中出现次数超过半数的元素(多数元素)。其核心思想通过抵消策略将时间复杂度优化至 O(n),空间复杂度为 O(1)。

核心原理

抵消策略 :不同元素相互抵消,最终剩余元素即为候选多数元素。
两阶段流程

  1. 候选阶段 :遍历数组,维护候选元素 candidate 和计数器 count。遇到相同元素时 count++,否则 count--;当 count=0 时更新候选元素。
  2. 验证阶段 :统计候选元素的实际出现次数,确认是否满足 > ⌊n/2⌋

代码实现

Java 示例
java 复制代码
public int majorityElement(int[] nums) {
    int candidate = 0, count = 0;
    for (int num : nums) {
        if (count == 0) candidate = num;
        count += (num == candidate) ? 1 : -1;
    }
    return candidate; // 假设多数元素存在
}

正确性证明

  • 数学基础 :多数元素出现次数 > n/2,抵消过程中其剩余数量始终占优。
  • 示例分析 :数组 [2,2,1,1,1,2,2] 的抵消过程:
    • 初始 candidate=2count=1
    • 遍历至第三个 1count=0,切换 candidate=1
    • 最终 candidate=2 为正确结果。

复杂度与优缺点

  • 时间复杂度:O(n),仅需一次或两次遍历。
  • 空间复杂度:O(1),仅需常数空间存储变量。
  • 优点:高效、简单,适用于数据流场景。
  • 缺点:仅适用于严格多数的情况,需验证阶段确保正确性。

应用场景

  • 选举系统:快速确定得票过半的候选人。
  • 数据分析:识别主要趋势或高频元素。
  • 分布式系统:多数共识算法的底层实现。
相关推荐
沪漂阿龙1 分钟前
Java JVM 面试题详解:JVM运行原理、内存模型、堆栈方法区、GC垃圾回收、JIT编译、类加载机制与线上调优全攻略
java·开发语言·jvm
小碗羊肉3 分钟前
Maven高级
java·开发语言·maven
搬砖者(视觉算法工程师)5 分钟前
计算机视觉与计算摄影测量学第三讲图像直方图:理论、统计特性与点运算变换
人工智能·算法·计算机视觉
星秀日10 分钟前
Spring Boot + Sa-Token 实时聊天系统:用户注册流程源码深度剖析
java·人工智能·spring·状态模式
Yingjun Mo10 分钟前
3. Meta-Harness:模型基座外壳的端到端优化
人工智能·算法
Cthy_hy12 分钟前
并查集(Disjoint Set Union):巧判「连通聚类关系」的极简利器
数据结构·算法
Shan120514 分钟前
C++中函数对象之重载 operator()
开发语言·c++·算法
逻辑君14 分钟前
物理生物学研究报告【20260007】
人工智能·算法
阿维的博客日记19 分钟前
简单说一下ArrayList的add机制,适合应试者表达的
算法·arraylist
吃好睡好便好24 分钟前
伽利略·伽利雷的故事
学习