This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <iostream>
#include <algorithm>
using namespace std;
const int Nmax=1000000;
struct island{
int h, t;
}e[Nmax*2+5];
int n, v[Nmax+1];
bool cmp(island a, island b){
return a.h<b.h;
}
int main()
{
cin>>n;
for (int i=0; i<n; i++)
cin>>v[i];
int mx=0, nris=0;
for (int i=0; i<n; i++){
if (mx<v[i])
mx=v[i];
if (v[i]<mx && v[i]<v[i+1]){
e[nris*2].t=1; e[nris*2].h=v[i];
e[nris*2+1].t=-1; e[nris*2+1].h=mx;
mx=0;
nris++;
}
}
e[nris*2].t=-1; e[nris*2].h=mx;
sort(e, e+nris*2+1, cmp);
int crt=1, i=0; mx=1;
while(i<=nris*2){
while (e[i].h==e[i+1].h){
crt+=e[i].t;
i++;
}
crt+=e[i].t;
if (crt>mx)
mx=crt;
i++;
}
cout<<mx;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |