Cod sursa(job #1025459)

Utilizator handz.FMI Andrei Tanasescu handz. Data 9 noiembrie 2013 23:49:00
Problema Elementul majoritar Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.7 kb
#include <iostream>
#include <fstream>
using namespace std;

ifstream f("elmaj.in");
ofstream g("elmaj.out");

#define maxN 1000005
int v[maxN],n;

void find_majority()
{
    int x,i,k,nr;
    x=-1;
    k=0;

    for(i=1; i<=n ;i++)
    {
        if(k==0)
        {
            x=v[i];
            k++;
        }
        else if(v[i]==x) k++;
        else k--;
    }

    if(x==-1) g<<x;
    else
    {
        nr=0;
        for(i=1; i<=n ;i++)
        {
            if(v[i]==x) nr++;
        }

        if(nr>=n/2+1) g<<x<<" "<<nr;
        else g<<-1;
    }
}

int main()
{
    f>>n;
    for(int i=1; i<=n ;i++)
        f>>v[i];
    find_majority();
    return 0;
}