Cod sursa(job #2695565)

Utilizator un_fes_galbendaniel guba un_fes_galben Data 13 ianuarie 2021 18:41:09
Problema Elementul majoritar Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.74 kb
#include <fstream>

using namespace std;
int v[1000005];
int main()
{
    ifstream fin("elmaj.in");
    ofstream fout("elmaj.out");
    int n;
    fin>>n;
    for(int i=1;i<=n;i++)
    {
        fin>>v[i];
    }
    int cand=v[1],cnt=1;
    for(int i=2;i<=n;i++)
    {
        if(cand==v[i])
        {
            cnt++;
        }
        else
        {
            cnt--;
            if(cnt==0)
            {
                cand=v[i];cnt=1;
            }
        }
    }
    cnt=0;
    for(int i=1;i<=n;i++)
    {
        if(v[i]==cand)
        {
            cnt++;
        }
    }
    if(cnt>=n/2+1)
    {
        fout<<cand<<" "<<cnt<<'\n';
    }
    else
    {
        fout<<"-1"<<'\n';
    }
    return 0;
}