码迷,mamicode.com
首页 > 编程语言 > 详细

候选人算法

时间:2014-11-11 20:53:38      阅读:185      评论:0      收藏:0      [点我收藏+]

标签:blog   io   ar   sp   for   div   log   bs   as   

现在有一个整数数组,已知一个数出现的次数超过了一半,请用O(n)的复杂度的算法找出这个数

#include <stdio.h>

int main(int argc, char **argv)
{
	int i, candidate, vote;
	int a[10]={1,2,3,1,2,1,1,6,1,1}; 

	candidate = 1<<31;
	vote = 0;
	for (i = 0; i < 10; i++) {
		if (a[i] != candidate) {
			if (vote == 0) {	/* 废掉candidate, 把a[i]作为新的候选人 */
				candidate = a[i];
				vote = 1;
			}
			else {			/* 候选人的票减1 */
				vote--;
			}
		}
		else {				/* 候选人的票加1 */
			vote++;
		}
	}
	// 最后剩下的候选人即为出现次数超过一半的数
	printf("candidate = %d, vote = %d\n", candidate, vote);

	return 0;
}

 

候选人算法

标签:blog   io   ar   sp   for   div   log   bs   as   

原文地址:http://www.cnblogs.com/kangbry/p/4090347.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!