Cod sursa(job #2321158)

Utilizator 222darkdarkAelx Paraschiv 222darkdark Data 15 ianuarie 2019 19:09:31
Problema Elementul majoritar Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.74 kb
#include <iostream>
#include <fstream>
using namespace std;

int v[3000001];

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

/**
Complexitate O(n)(liniara)
*/

int main()
{
    int N;
    int nr = 0, cand = -1;
    f >> N;
    for(int i = 1; i <= N; i++)
    {
        f >> v[i];
        if(nr == 0)
        {
            cand = v[i];
            nr = 1;
        }
        else
            if(cand == v[i])
                nr++;
            else
                nr--;
    }
    //
    if(nr > 0)
    {
        nr = 0;
        for(int i = 1; i <= N; i++)
            if(v[i] == cand)
                nr++;
    }
    if(nr > N / 2)
        g << cand << ' ' << nr;
    else
        g << -1;
    return 0;
}