Cod sursa(job #1203319)

Utilizator diana97Diana Ghinea diana97 Data 30 iunie 2014 20:10:32
Problema Elementul majoritar Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.6 kb
#include <iostream>
#include <fstream>

using namespace std;

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

const int NMAX = 1000000 + 1;

int n;
int v[NMAX];

void elmaj () {
    int k = 0, cand = -1;
    for (int i = 1; i <= n; i++) {
        f >> v[i];
        if (k == 0) cand = v[i], k++;
        else if (v[i] == cand) k++;
        else k--;
    }
    int nr = 0;
    for (int i = 1; i <= n; i++)
        if (v[i] == cand) nr++;
    if (nr >= (n + 1) / 2) g << cand << ' ' << nr;
    else g << -1;
    g << '\n';
}

int main () {
    f >> n;
    elmaj();
    return 0;
}