给定一个大小为
n
的数组nums
,返回其中的多数元素。多数元素是指在数组中出现次数 大于⌊ n/2 ⌋
的元素。你可以假设数组是非空的,并且给定的数组总是存在多数元素。
示例 1:
输入:nums = [3,2,3] 输出:3
此算法用到了一个很重要的算法--摩尔投票算法,详细参见--一篇搞懂面试高频算法--摩尔投票算法-CSDN博客
知道这个概念后,就可以得到以下解题过程:
class Solution {
public int majorityElement(int[] nums) {
int out=nums[0];//从0开始匹配(本质选谁都行)
int count=1; //从1开始计数
for(int i=1;i<nums.length;i++){ //由于out从0开始匹配,所以这里从1开始
if(out==nums[i]){
count++;
}else{
if(count==0){
out=nums[i];
count=1;
}
count--;
}
}
return out;
}
}