Cod sursa(job #2170888)

Utilizator LittleWhoFeraru Mihail LittleWho Data 15 martie 2018 10:14:08
Problema Elementul majoritar Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.93 kb
#include <bits/stdc++.h>

using namespace std;

const int nmax = static_cast<int> (1e9 + 1);
int v[nmax];
int n;

int main() {
    freopen("carici.in", "r", stdin);

    //freopen("algsort.in", "r", stdin);
    //freopen("algsort.out", "w", stdout);

    scanf("%d", &n);
    for (int i = 1; i <= n; i++) {
        scanf("%d", &v[i]);
    }

    int candidate = -1;
    int k = 0;

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

    if (candidate < 0) {
        cout << "-1\n";
    } else {
        k = 0;
        for (int i = 1; i <= n; i++) {
            if (v[i] == candidate) {
                k++;
            }
        }

        if (k > n / 2) {
            cout << candidate << " " << k << "\n";
        } else {
            cout << "-1\n";
        }
    }

    return 0;
}