Cod sursa(job #1687235)

Utilizator vivedelweissviv edelweiss vivedelweiss Data 12 aprilie 2016 18:50:50
Problema Elementul majoritar Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 1.25 kb
#include <iostream>
#include <fstream>
using namespace std;
int n;
struct nod
{
    int numar, ap;
    nod *urm;
};
nod *pr,*ul,*maxim;
void inserare (nod *&pr, nod*&ul, int x)
{
    if (pr==NULL)
    {
        pr=new nod;
        pr->numar=x;
        pr->ap=1;
        pr->urm=NULL;
        ul=pr;
        maxim=pr;
    }
    else
    {
        nod *p=pr;
        while (p&&p->numar!=x)
            p=p->urm;
        if (p){
            p->ap++;
           // if (p->ap>maxim->ap)
           //     maxim=p;
        }
        else {
            p=new nod;
            p->numar=x;
            p->ap=1;
            p->urm=NULL;
            ul->urm=p;
            ul=p;
        }
    }
}
ofstream g("elmaj.out");
bool cauta_maj(nod*pr)
{
    nod *p=pr;
    while (p&&p->ap<=n/2)
            p=p->urm;
    if (p==NULL) return false;
    g<<p->numar<<" "<<p->ap;
    return true;
}

int main()
{   ifstream f("elmaj.in");

    int i,x;
    f>>n;
    for (i=1;i<=n;i++)
        {
            f>>x;
            inserare(pr,ul,x);
        }
    if (cauta_maj(pr)==false) g<<-1;

//    if ((maxim->ap)>n/2)
//        g<<maxim->numar<<" "<<maxim->ap;
//    else g<<-1;
    f.close();
    g.close();
    return 0;
}