Cod sursa(job #2085095)

Utilizator Mihai145Oprea Mihai Adrian Mihai145 Data 9 decembrie 2017 18:07:27
Problema Elementul majoritar Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.71 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("elmaj.in");
ofstream fout("elmaj.out");
int n;
vector <unsigned long long> v;
int main()
{
    int i, x, cnt, ap=0;
    unsigned long long soi;
    fin>>n;
    for(i=0; i<=n-1; i++)
    {
        fin>>x;
        v.push_back(x);
    }
    cnt=1;
    soi=v[0];
    for(i=1; i<=n-1; i++)
    {
        if(v[i]==soi)
            cnt++;
        else
        {
            cnt--;
            if(cnt==0)
            {
                cnt=1;
                soi=v[i];
            }
        }
    }
    for(i=0; i<=n-1; i++)
        if(v[i]==soi) ap++;
    if(ap>=n/2+1) fout<<soi<<' '<<ap<<'\n';
    else fout<<-1<<'\n';
    return 0;
}