1.解答之前的碎碎念:
又是一道没有思路的题。。。but我现在觉得,学习新知识过程都是从模仿开始的,比如先看别人的代码是怎么优雅的解决一个问题的,然后探究为什么要这么写,然后慢慢学着也这么做,最后知识就变成自己的啦~哈哈哈,给自己灌了一大壶鸡汤呢。
2.问题描述:
给定一个大小为 n 的数组,找到其中的众数。众数是指在数组中出现次数大于 ⌊ n/2 ⌋
的元素。
你可以假设数组是非空的,并且给定的数组总是存在众数。
示例 1:
输入: [3,2,3]
输出: 3
示例 2:
输入: [2,2,1,1,1,2,2]
输出: 2
3.解答思路:
摩尔投票算法:
先假设第一个元素为众数,计数器置为1,遍历数组,当遇到相同的元素时,计数器加1,否则减1,任何计算器为0的时候,就假设下一个元素为众数,计数器再置为1。循环结束时,返回我们假设的众数,即要求的众数。
4.答案:
class Solution {
public:
int majorityElement(vector<int>& nums) {
int value = nums[0];
int count = 1;
for(int i = 1;i < nums.size();i++)
{
if(nums[i] != value)
{
count--;
}
else
{
count++;
}
if(count == 0)
{
value = nums[i];
count = 1;
}
}
return value;
}
};