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

应用场景

  • 选举系统:快速确定得票过半的候选人。
  • 数据分析:识别主要趋势或高频元素。
  • 分布式系统:多数共识算法的底层实现。
相关推荐
云烟成雨TD15 小时前
Spring AI Alibaba 1.x 系列【44】多智能体 - 混合模式、监督者(SupervisorAgent)、自定义模式
java·人工智能·spring
tjl521314_2115 小时前
01C++ 分离编译与多文件编程
前端·c++·算法
_日拱一卒15 小时前
LeetCode:23合并K个升序链表
java·数据结构·算法·leetcode·链表·职场和发展
cany100015 小时前
C++ -- 泛型编程
java·开发语言·c++
lee_curry15 小时前
第三章 jvm中的对象和执行引擎
java·jvm·执行引擎
哆啦刘小洋15 小时前
【LeetCode每日一题】:2033(贪心+快速排序魔改)
算法·leetcode
wang090715 小时前
Linux性能优化之文件系统基础介绍
java·linux·性能优化
WolfGang00732115 小时前
代码随想录算法训练营 Day48 | 图论 part06
算法·图论
Nice_Fold15 小时前
Kubernetes探针机制与Deployment控制器(自用笔记)
笔记·容器·kubernetes
cheems952715 小时前
[算法手记] 动态规划 ,二维费用限制背包问题如何处理
算法·动态规划