题目描述:
给定一个大小为 n 的数组,找到其中的众数。众数是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在众数。
示例 1:
输入: [3,2,3] 输出: 3
示例 2:
输入: [2,2,1,1,1,2,2]
输出: 2
思路:关注题目中的限定条件:大于 ⌊ n/2 ⌋、总是存在众数
class Solution {
public:
int majorityElement(vector<int>& nums)
{
int major = nums[0];
int count = 1;
for(int i=1; i<nums.size(); i++){
if(nums[i] == major)
count++;
else{
count--;
if(count == 0)
{
major = nums[i];
count = 1;
}
}
}
return major;
}
};

本文介绍了一种在数组中寻找众数的算法,众数是在数组中出现次数超过一半的元素。通过一次遍历和计数的方式,有效地找出满足条件的众数。示例包括了如何使用该算法处理具体的输入数据。
345

被折叠的 条评论
为什么被折叠?



