pat 1054 The Dominant Color

求数组中出现次数超过一半的数字,排序再取中位数太慢,hash表记录出现次数,空间复杂度太高,从另一个角度来看,出现次数超过一半的数字,其出现次数比其它所有数出现之和还多,每次从数组中除去两个不同的数字,直到最后,剩下的肯定是所求。用cad(候选)表示所求的数,nTime为它出现的次数。依次遍历数组,若a[i]和cad不同则nTime--; 若相同则nTime++;  若nTime为0, 则取下一个数作为cad(候选)。

AC代码:

#include<iostream>
using namespace std;

const int MAXN = 10000;
int img[MAXN]={0};

int main()
{
	int m,n,mn;
	int i,j,x;
	freopen("C:\\Documents and Settings\\Administrator\\桌面\\input.txt","r",stdin);

	bool fg = false;
	//cin>>m>>n;
	scanf("%d%d",&m,&n);
	mn = m * n;
	for(i = 0; i < mn; i++){		
		//cin>>img[i];
		scanf("%d",&img[i]);		
	}
	int cad, nTime=0;
	for(i = 0; i < mn; i++){
		if(nTime == 0){
			cad = img[i];
			nTime = 1;
		} else {
			if(cad == img[i])
				nTime++;
			else 
				nTime--;			
		}
	}
	//cout<<cad;
	printf("%d",cad);
	return 0;
}


 

你可能感兴趣的:(pat 1054 The Dominant Color)