Cod sursa(job #1595688)

Utilizator T.C.11Tolan Cristian T.C.11 Data 10 februarie 2016 14:43:08
Problema Elementul majoritar Scor 20
Compilator cpp Status done
Runda Arhiva educationala Marime 0.81 kb
#include <fstream>

using namespace std;

ifstream fin("elmaj.in");
ofstream fout("elmaj.out");

int n,x,candidat,k,i,nr;

int main()
{
    fin>>n;
    candidat = -1;
    k=0;
    for (i=1;i<=n;++i)
    {
        fin>>x;
        if (k==0)
        {
            candidat=x;
        }
        else
        {
            if (x == candidat)
                k++;
            else
                k--;
        }
    }
    if (candidat < 0 )
        fout<<candidat;
    else
    {
        fin.close();
        ifstream fin("elmaj.in");
        fin>>n;
        for (i=1;i<=n;i++)
        {
            fin>>x;
            if (x == candidat)
                nr++;
        }
        if (nr > n/2)
            fout<<candidat<<" "<<nr;
        else
            fout<<"-1";
    }

    return 0;
}