Cod sursa(job #1915017)
Utilizator | Data | 8 martie 2017 19:20:45 | |
---|---|---|---|
Problema | Elementul majoritar | Scor | 20 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.93 kb |
#include <cstdio>
using namespace std;
int sir[1000005];
int main()
{
freopen("elmaj.in", "r", stdin);
freopen("elmaj.out", "w", stdout);
int n;
scanf("%d", &n);
int nr = 0;
int vot;
int tmp;
for(int i = 0; i < n; i++)
{
scanf("%d", &sir[i]);
if(nr == 0)
{
nr++;
vot = sir[i];
}
else
{
if(vot == tmp)
{
nr++;
}
else
{
nr--;
}
}
}
if(nr == 0)
{
printf("-1");
return 0;
}
nr = 0;
for(int i = 0; i < n; i++)
{
if(sir[i] == vot)
{
nr++;
}
}
if(nr >= (n / 2) + 1)
{
printf("%d %d", vot, nr);
}
else
{
printf("-1");
}
return 0;
}