给定一个大小为 n 的数组,找到其中的多数元素。多数元素是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在多数元素。
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/majority-element
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
int majorityElement(int* nums, int numsSize){
int ret = nums[0];
int count = 1;
for(int i = 1; i < numsSize; i++)
{
if(ret == nums[i])
count++;
else
count--;
if(count == 0)
{
count = 1;
ret = nums[i];
}
}
return ret;
}
思路:摩尔投票法
假设n/2个国家在打架,每个不同的数字代表不同的国家。那么两个不同的数字就会抵消,相同的数字就会战力加1,那么某个国家的战力在n/2以上,就可以得出这个国家为那个数字。