题目描述
给定一个大小为 n 的数组,找到其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在多数元素。
示例 1:
输入:[3,2,3]
输出:3
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/majority-element
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
C++
class Solution {
//这道题对我来说,难在如何将空间复杂度保持为O(1),不管空间复杂度就可以
//多数元素肯定只有一个
//摩尔投票原理,多数元素和它所有不相同的元素抵消,肯定还剩下
public:
int majorityElement(vector<int>& nums) {
int count=1;
int temp=nums[0];
for(int i=1; i<nums.size();i++){
if(temp==nums[i]){
count++;
}else{
count--;
if(count==0){
count=1;
temp=nums[i];
}
}
}
return temp;
}
};