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