数组中占比超过一半的元素称之为主要元素。给定一个整数数组,找到它的主要元素。若没有,返回-1。
示例 1:
输入:[1,2,5,9,5,9,5,5,5]
输出:5
示例 2:
输入:[3,2]
输出:-1
示例 3:
输入:[2,2,1,1,1,2,2]
输出:2
解法:通过分析题目可以发现,超过半数的元素,肯定只会存在一个元素(受数组长度的限制),于是可以设置一个major用于保存当前遍历的元素,一个cnt用于判断,一旦出现与当前元素(major)不一样的元素,则cnt–;若下一个元素与major相同,则cnt++。当cnt为0,则更新major。
这样遍历完成后,major就是出现次数最多的元素,然后判断major出现的次数,若超过一半则输出major;若没超过,则输出-1.
class Solution {
public int majorityElement(int[] nums) {
int cnt = 0;
int major = 0;
for(int i = 0;i<nums.length;i++){
if(cnt == 0){
major = nums[i];
cnt++;
}else{
if(major == nums[i]){
cnt++;
}else{
cnt--;
}
}
}
int C = 0;
for(int n:nums){
if(major == n){
C++;
}
}
if(C<=nums.length/2){
major = -1;
}
return major;
}
}