Mai intai trebuie sa te autentifici.
Cod sursa(job #2290929)
| Utilizator | Data | 27 noiembrie 2018 10:35:56 | |
|---|---|---|---|
| Problema | Elementul majoritar | Scor | 20 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.96 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("elmaj.in");
ofstream out("elmaj.out");
struct nod
{
int info;
nod *next;
}*prim;
void push(int k)
{
nod *p=new nod;
p->info=k;
p->next=prim;
prim = p;
}
int pop()
{
if(prim != NULL)
{
int k=prim->info;
prim=prim->next;
return k;
}
return -1;
}
int peek()
{
if(prim != NULL)
return prim->info;
return -1;
}
int main()
{
int n,v[100],c=0;
in >> n;
for(int i=0;i<n;i++)
in >> v[i];
for(int i=0;i<n;i++)
{
if(peek()==-1)
push(v[i]);
else
{
if(peek()!=v[i])
pop();
else
push(v[i]);
}
}
for(int i=0;i<n;i++)
if(v[i]==prim->info)
c++;
if(c>n/2)
out << prim->info << " " << c;
else out << -1;
return 0;
}
