[LeetCode练习题-C语言]169. Majority Element
题目
Given an array of size n, find the majority element. The majority element is the element that appears more than ⌊ n/2 ⌋ times.
You may assume that the array is non-empty and the majority element always exist in the array.
这道题我没想到好的方法做,最开始用struct结构体记录每个数出现频率,太麻烦!在网上参考到许多较好的思路,如
http://www.cnblogs.com/ganganloveu/p/4177690.html
思路为:
每找出两个不同的element,则成对删除。最终剩下的一定就是所求的。
可扩展到⌊ n/k ⌋的情况,每k个不同的element进行成对删除。
代码如下
int majorityElement(int* nums, int numsSize) {
int count = 0;
int element,i;
for(i=0; i<numsSize; i++){
if(count == 0){
element = nums[i];
count = 1;
}else{
if(nums[i] == element){
count++;
}else{
count--;
}
}
}
return element;
}