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;
}
};
本文来自博客园,作者:{BailanZ},转载请注明原文链接:https://www.cnblogs.com/BailanZ/p/16075610.html