Cod sursa(job #2875306)

Utilizator dcovDarius Covaciu dcov Data 21 martie 2022 13:22:40
Problema Elementul majoritar Scor 10
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.73 kb
#include <iostream>
#include <fstream>
using namespace std;

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

int n,a[1000010];

void cit()
{
    f>>n;

    for(int i=0;i<n;i++)
        f>>a[i];
}

int elemmaj()
{
    int cand=-1,k=0,nr=0;

    for(int i=0;i<n;i++)
    {
        if(k==0)
        {
            cand=a[i];
            k=-1;
        }
        else  if(a[i]==cand)
            k++;
        else
            k--;
    }

    if(cand<0)
        return -1;

    for(int i=0;i<n;i++)
        if(cand==a[i])
            nr++;

    if(nr>=n/2+1)
    {
        g<<cand<<' ';

        return nr;
    }

    return -1;
}

int main()
{
    cit();

    g<<elemmaj();

    return 0;
}