您的位置:首页 > 编程语言 > C语言/C++

[LeetCode练习题-C语言]169. Majority Element

2016-07-27 15:34 393 查看

[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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  leetcode c语言