Pagini recente » Cod sursa (job #657051) | Cod sursa (job #1990583) | Istoria paginii utilizator/6emmae2785yh4 | Cod sursa (job #2686025) | Cod sursa (job #1489031)
#include <fstream>
using namespace std;
ifstream f("elmaj.in");
ofstream g("elmaj.out");
int solve(int n, int a[]) {
int cand = -1, k = 0;
for (int i = 0; i < n; i++) {
if (k == 0) {
cand = a[i];
k = 1;
} else if (a[i] == cand) {
k++;
} else
k--;
}
if (cand < 0)
return cand;
// verificare
int nr = 0;
for (int i = 0; i < n; i++) {
if (a[i] == cand)
nr++;
}
if (nr > n / 2)
return cand;
else
return -1;
}
int main()
{
int n,a[1000000];
f>>n;
for(int i=0;i<n;i++)
f>>a[i];
g<<solve(n,a);
}