Cod sursa(job #1791137)
| Utilizator | Data | 29 octombrie 2016 09:50:27 | |
|---|---|---|---|
| Problema | Elementul majoritar | Scor | 60 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.4 kb |
#include <cstdio>
using namespace std;
int n,i,a[100003],c,nr,nra;
int main()
{freopen("elmaj.in","r",stdin);
freopen("elmaj.out","w",stdout);
scanf("%d",&n);
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
nr=1;c=a[i];
for(i=2;i<=n;i++){
if(a[i]==c)nr++;
else nr--;
if(nr<0){c=a[i];nr=0;}
}
for(i=1;i<=n;i++)
if(a[i]==c)nra++;
if(nra>n/2)printf("%d %d",c,nra);
else printf("-1");
return 0;
}
