Cod sursa(job #3205237)

Utilizator vladneaguvladCristianoRonaldo vladneagu Data 19 februarie 2024 09:39:59
Problema Elementul majoritar Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.72 kb
#include <fstream>
using namespace std;
int a[100000];
int realCount = 0;
ifstream cin("elmaj.in");
ofstream cout("elmaj.out");
int maj(int n){
    int canditate=-1;
    int count=0;
    for (int i = 0; i < n; i++) {
        if(count==0){
            canditate=a[i];
            count=1;
        }else if(canditate==a[i]){
            count++;
        }else{
            count--;
        }
    }
    for (int i = 0; i < n; i++) {
        if (a[i] == canditate)
            realCount++;
    }
    if (realCount > n / 2)
        return canditate;
    return -1;
}
int main()
{
    int n;
    cin>>n;
    for (int i = 0; i < n; i++) {
        cin>>a[i];
    }
    if(maj(n)!=-1)cout<<maj(n)<<" "<<realCount/2;
    else cout<<-1;
    return 0;
}