pat 1054 The Dominant Color

16 篇文章 0 订阅
8 篇文章 0 订阅

求数组中出现次数超过一半的数字,排序再取中位数太慢,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;
}


 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值