[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上169题Majority Element的解题思路与C语言实现。通过巧妙的方法,只需遍历一次数组即可找到众数,避免了使用结构体记录每个元素的频率。
1447

被折叠的 条评论
为什么被折叠?



