Boyer-Moore投票算法

上帝视角:我们将nums中的元素依次和真正的众数mode去比,是+1,否-1,用val来记录。

平民视角:设置一个计数器。首先我们将nums的第一个元素设置成众数,依次和后面的数去比较。和此众数相同则+1,不同则-1。当count=0时,记下一个元素为众数。重复此步骤。

示例如下

$$
nums:[7,7,5,7,5,1|5,7|5,5,7,7|7,7,7,7]\\ count:[1,2,1,2,1,0|1,0|1,2,1,0|1,2,3,4]\\ val: [1,2,1,2,1,0|-1,0|-1,-2,-1,0|1,2,3,4]
$$

我们可以发现,count要么和val相等,要么相反。因此我们可以用过count来找到众数。count为负时我们将其取正即可,即当count=-1,令count=1

下面是关于用Boyer-Moore算法求众数的示例。平均时间复杂度为O(n),平均空间复杂度为O(1)。

C++代码实现

class Solution {
public:
    int majorityElement(vector<int>& nums) {
        int mode = -1;
        int count = 0;
        for (int num : nums) {
            if (num == mode)
                ++count;
            else if (--count < 0) {//否则count自减1并且进行是否为0判断
                mode = num;
                count = 1;//相当于变成val
            }
        }
        return mode;
    }
};
 

Python代码实现

    def majorityElement(self, nums: List[int]) -> int:
        mode,count=None,0
​
        for num in nums:
            if count==0:
                mode=num
            count+=(1 if num==mode else -1)
        
        return mode

参考文献

LeetCode面试150——169多数元素

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Boyer-Moore投票法是一种用于查找元素序列中的众数的算法,它具有线性时间复杂度和常数级空间复杂度。该算法由Robert S. Boyer和J Strother Moore命名,是一种典型的流算法。\[1\] Boyer-Moore投票法分为两个阶段:抵消阶段和计数阶段。在抵消阶段,两个不同的候选人进行对抗,并同时抵消各自的一张票。如果两个候选人相同,则累加可抵消的次数。在计数阶段,如果抵消阶段最后得到的抵消计数不为0,那么这个候选人有可能超过一半的票数。为了验证这一点,需要遍历一次元素序列,统计票数,才能确定最终的众数。\[2\] 更多关于Boyer-Moore投票法的详细信息可以参考\[3\]。 #### 引用[.reference_title] - *1* *3* [摩尔投票算法](https://blog.csdn.net/qq_17550379/article/details/83818965)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [摩尔(Boyer-Moore)投票法](https://blog.csdn.net/qq_40692109/article/details/104805815)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值