Cod sursa(job #1276335)
Utilizator | Data | 26 noiembrie 2014 10:58:05 | |
---|---|---|---|
Problema | Elementul majoritar | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.64 kb |
#include <fstream>
using namespace std;
ifstream in("elmaj.in");
ofstream out("elmaj.out");
int v[1000001];
int main()
{
int n,val,i,nr=1;
in>>n;
for(i=1; i<=n; i++)
{
in>>v[i];
}
val=v[1];
for(i=2; i<=n; i++)
{
if(v[i]==val)
nr++;
else
{
nr--;
if(nr==0)
{
val=v[i];
nr=1;
}
}
}
nr=0;
for(i=1; i<=n; i++)
if(v[i]==val)
nr++;
if(nr>n/2)
out<<val<<" "<<nr;
else
out<<"-1";
return 0;
}