摩尔投票法

Posted -citywall123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了摩尔投票法相关的知识,希望对你有一定的参考价值。

在一个无序数组中,存在一个数,它出现的次数大于数组长度的一半。输出这个数

 

一、排序、遍历

 

二、摩尔投票法

摩尔投票算法是一种使用线性时间和常数空间查找大部分元素序列的算法。

最简单的形式就是,查找输入中重复出现超过一半以上(必须大于n/2,等于不算)的元素。如果序列中没有这种元素,算法不能检测到正确结果,将输出其中的一个元素之一。
如果不能保证输入数据中有占有一半以上的元素,需要再遍历一下验证。

满足两个先决条件

1、出现超过一半以上(n/2)的元素有且只有一个;

2、这个元素一定存在

 

算法步骤

我们维护一个局部变量作为当前查找元素,一个局部变量作为计数器,

当遍历开始的时候,此时计数(count)为0,则将数组第一个元素作为当前查找元素;

当遍历的元素与查找元素相等,计数加1;反之则-1;

若当计数为0时,将下一个元素作为当前查找元素,继续重复以上操作;当遍历结束时,当前查找元素则为目标元素。

 
#include<iostream>
using namespace std;
int main() {
    
    int nums[100];
    int count = 1;
    int e = nums[0];
    int n, x;
    cin >> n;
    for (int i = 0; i < n; i++) {
        cin >> nums[i];
    }
    for (int i = 1; i < n; i++) {
        if (e == nums[i])
            count++;
        else if (count != 0) {
            count--;
        }
        else if (count == 0)
            e = nums[i];
    }
    cout << e << endl;

    system("pause");
    return 0;
}

 

以上是关于摩尔投票法的主要内容,如果未能解决你的问题,请参考以下文章

你听说过摩尔投票法吗

LeetCode169. 多数元素(摩尔投票法)

摩尔投票法

leetcode打卡--moore投票法的运用详解

Boyer–Moore Majority Vote Algorithm摩尔投票法,众数算法,Java

Boyer–Moore Majority Vote Algorithm摩尔投票法,众数算法,Java