168 多数元素

169. 多数元素

难度简单1376

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

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

示例 1:

输入:[3,2,3]
输出:3

示例 2:

输入:[2,2,1,1,1,2,2]
输出:2

进阶:

  • 尝试设计时间复杂度为 O(n)、空间复杂度为 O(1) 的算法解决此问题。

本题思路较多,但是较简单,所以直接去想进阶的答案

使用了摩尔投票法,只遍历一次

class Solution {
public:
    //摩尔投票法,遇到相同的数,就投一票,遇到不同的数,就减一票,最后还存在票的数就是众数
    //简单来说,就是众数一定是比非众数多的,如果票数为0那就更换候选人,最后票数为正的候选人就是众数
    int majorityElement(vector<int>& nums)
    {
        int count=0,result=-1;
        for(const auto& num:nums)
        {
            if(count==0)result=num;
            if(num==result)++count;
            else --count;
        }
        return result;
    }
};
posted @ 2022-03-30 10:04  BailanZ  阅读(29)  评论(0编辑  收藏  举报