Submission #83655

#TimeUsernameProblemLanguageResultExecution timeMemory
83655nikolapesic2802Untitled (POI11_tem)C++14
56 / 100
858 ms33792 KiB
#include <bits/stdc++.h> using namespace std; #define ll long long #define pb push_back int ma; const int N=2*1e6+5; int m[N]; int n; int i,k,l0,l,r,r0,nn; int maxx=INT_MIN; int res=0; int hi,lo,mid,d,a; struct SegmentTree{ void set() { a+=n; m[a]=k; a>>=1; for(;a;a>>=1) m[a]=max(m[2*a],m[2*a+1]); } int get() { ma=INT_MIN; for(l0+=n,r0+=n;l0<=r0;l0>>=1,r0>>=1) { if(l0%2==1) { ma=max(ma,m[l0]); l0++; } if(r0%2==0) { ma=max(ma,m[r0]); r0--; } } return ma; } }; int main() { SegmentTree m; //n=1e6; scanf("%i",&n); assert(n<N); for(i=0;i<n;i++) { scanf("%i %i",&lo,&hi); a=i; k=lo; m.set(); if(hi<maxx) { l++; r=i; while(l<r) { mid=(l+r)/2; l0=mid; r0=i; d=m.get(); //printf("%i-%i [%i][%i]=%i\n",l,r,mid,i,d); if(hi<d) { l=mid+1; } else { r=mid; } } l0=l; r0=i; maxx=m.get(); } maxx=max(maxx,lo); res=max(res,i-l+1); } printf("%i\n",res); return 0; }

Compilation message (stderr)

tem.cpp: In function 'int main()':
tem.cpp:49:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%i",&n);
     ~~~~~^~~~~~~~~
tem.cpp:53:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%i %i",&lo,&hi);
         ~~~~~^~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...