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),仅需常数空间存储变量。
  • 优点:高效、简单,适用于数据流场景。
  • 缺点:仅适用于严格多数的情况,需验证阶段确保正确性。

应用场景

  • 选举系统:快速确定得票过半的候选人。
  • 数据分析:识别主要趋势或高频元素。
  • 分布式系统:多数共识算法的底层实现。
相关推荐
JavaEdge.2 小时前
Chrome加载已解压的扩展程序-清单文件缺失或不可读取 无法加载清单
java
iReachers2 小时前
HTML打包EXE配置管理教程:多项目打包设置一键保存、加载与切换
java·前端·javascript
XiYang-DING2 小时前
【Java】堆
java·开发语言
Lyyaoo.2 小时前
【Java基础面经】Java 反射机制
java·开发语言·python
雨浓YN2 小时前
OPC UA 通讯开发笔记 - 基于Opc.Ua.Client
笔记·c#
YXWik62 小时前
Langchain4j(1)基础对话+连续对话+工具调用 + 流式响应+结构化 JSON 输出
java
kobesdu2 小时前
FAST-LIO2 + 蓝海M300激光雷达:从建图到实时栅格图的完整流程
算法·机器人·ros·slam·fast lio
沪漂阿龙2 小时前
深度剖析神经网络学习:从损失函数到SGD,手写数字识别完整实战
人工智能·神经网络·学习
x_xbx2 小时前
LeetCode:438. 找到字符串中所有字母异位词
算法·leetcode·职场和发展