leetcode学习笔记2:多数元素(摩尔投票算法)

一、摩尔投票算法

摩尔投票算法(Boyer-Moore Majority Vote Algorithm)是一种高效的寻找多数元素的算法,其核心优势在于时间复杂度为 O (n),空间复杂度为 O (1),非常适合在大数据量下寻找出现次数超过总数一半的元素。

算法核心思想

多数元素的定义是:在数组中出现次数 > ⌊n/2⌋(即超过数组长度的一半)。这意味着,即使多数元素与其他所有元素 "两两抵消",最终剩下的一定是多数元素。

1.我们维护一个候选元素和一个计数器

2.遍历数组时,如果计数器为 0,我们将当前元素设为候选

3.遇到与候选相同的元素,计数器加 1,否则减 1

4.最终剩下的候选元素就是多数元素

算法题1:
力扣算法题 169. 多数元素

给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素。

你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例 1:

输入:nums = [3,2,3]

输出:3

示例 2:

输入:nums = [2,2,1,1,1,2,2]

输出:2

java 复制代码
public int majorityElement(int[] nums) {
    //用"摩尔投票算法"
    // 初始化计数器和候选元素
    int candidate = nums[0];
    int count = 1;
    for (int i=1;i<nums.length;i++){
        // 如果计数器为0,选择当前元素作为新的候选
        if (count==0){
            candidate = nums[i];
        }

        // 如果当前元素与候选相同,计数器加1,否则减1
        if (candidate==nums[i]){
            count ++;
        }
        else {
            count--;
        }
    }
    return candidate;
}
相关推荐
三品吉他手会点灯1 天前
C语言学习笔记 - 20.C编程预备计算机专业知识 - 变量为什么必须的初始化【重点】
c语言·笔记·学习
sakiko_1 天前
UIKit学习笔记1-创建项目(使用UIKit)、使用组件
笔记·学习
Old Uncle Tom1 天前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆1 天前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移1 天前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业1 天前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
圣保罗的大教堂1 天前
leetcode 1855. 下标对中的最大距离 中等
leetcode
星幻元宇VR1 天前
VR航空航天科普设备【VR时空直升机】
科技·学习·安全·生活·vr
_李小白1 天前
【android opencv学习笔记】Day 2: Mat类(图片数据结构体)
android·opencv·学习
智者知已应修善业1 天前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机