Boyer-Moore 投票算法

简介: 这里先贴题目:

这里先贴题目ba49e6a3c9d84b8ebfbb8d28cca84d97.png

Boyer-Moore 投票算法:

通俗点来讲,就是占领据点,像攻城那样,对消。


当你的据点有人时对消,无人时就占领。


这道题使用该算法可实现时间复杂度为O(n),空间复杂度为O(1),接下来看代码:

int majorityElement(int* nums, int numsSize) {
    int amzing = nums[0];
    int count = 0;
    for (int i = 0; i < numsSize; i++)
    {
        if (amzing == nums[i])
            count++;
        else if (count == 0)
        {
            amzing = nums[i];
            count++;
        }
        else
            count--;
    }
    return amzing;
}

我们定义一个amzing先记录数组第一个数字,并且数量为0,然后遍历整个数组,当count不为0时,数字不同时相消,数字相同时增加,当count为0时,amzing换其他数字,再增加数量。


通俗点讲:定义一个士兵,数量为0,遍历所有人,当count不为0,如果数字不同,就是遇到敌人,同归于尽,数字相同,遇到友军就加入。当count等于0,据点无人,哪个数字也可以占领。但是有一个阵营的人数占了大半,无论怎么对拼相消,剩下的一定是那个阵营的,也就是那个大半的数字。


排序:

int cmp(void* p1,void* p2)
{
    return *(int*)p1 - *(int*)p2;
}
int majorityElement(int* nums, int numsSize){
    qsort(nums,numsSize,4,cmp);
    return nums[numsSize/2];
}
目录
相关文章
|
19天前
|
算法 搜索推荐 程序员
第六十四练 字符串匹配 - Boyer-Moore算法
第六十四练 字符串匹配 - Boyer-Moore算法
22 0
|
12月前
|
算法 搜索推荐 安全
Boyer-Moore 字符串匹配算法
Boyer-Moore 字符串匹配算法
193 1
Boyer-Moore 字符串匹配算法
|
算法 Java Linux
字符串查找算法总结(暴力匹配、KMP 算法、Boyer-Moore 算法和 Sunday 算法)
总结字符匹配的多种经典算法并给出Java实现。
3562 0
|
算法
基于投票的热门计数算法策略
类似基于投票的热门计数算法普遍应用在热门文章,热门评论等场景中, 典型的比如网易和今日头条的评论区,国外比如Hacker News和Reddit的主题排序。
3600 0
|
4天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于DCT变换和位平面分解的数字水印嵌入提取算法matlab仿真
这是一个关于数字水印算法的摘要:使用MATLAB2022a实现,结合DCT和位平面分解技术。算法先通过DCT变换将图像转至频域,随后利用位平面分解嵌入水印,确保在图像处理后仍能提取。核心程序包括水印嵌入和提取,以及性能分析部分,通过PSNR和NC指标评估水印在不同噪声条件下的鲁棒性。