Submission #1096329

#TimeUsernameProblemLanguageResultExecution timeMemory
1096329kingdragonGlobal Warming (CEOI18_glo)C++14
100 / 100
394 ms28232 KiB
#include <bits/stdc++.h> #define F first #define S second #define pb push_back #define ll long long #define ii pair<int,int> #define iii pair<int,pair<int,int>> #define iil pair<ll,ll> #define iiil pair<ll,pair<ll,ll>> #define oo 1e18 #define check(n) (prime[n>>6]&(1<<((n&63)>>1))) #define set(n) prime[n>>6]|=(1<<((n&63)>>1)) using namespace std; const int N=2e5+5; const ll Mod=1e9+7; const ll MOD=13141702292180207; const int dx[]={-1,0,0,1}; const int dy[]={0,-1,1,0}; int n, a[N], st[4*N], d[N], cnt[N]; int t[N], s[N], x; set<int> m; vector<int> b, c[N]; void build(int id,int l, int r) { if (l>r) return; if (l==r) { st[id]=c[l][c[l].size()-1]; return; } int mid=(l+r)/2; build(id*2,l,mid); build(id*2+1,mid+1,r); st[id]=max(st[id*2],st[id*2+1]); } void up(int id,int l,int r, int u,int val) { if (u>r || l>u || l>r) return; if (l==r) { st[id]=val; return; } int mid=(l+r)/2; up(id*2,l,mid,u,val); up(id*2+1,mid+1,r,u,val); st[id]=max(st[id*2],st[id*2+1]); } int get(int id,int l,int r,int u,int v) { if (l>r || u>v || l>v || u>r) return 0; if (u<=l && r<=v) return st[id]; int mid=(l+r)/2; return max(get(id*2,l,mid,u,v), get(id*2+1,mid+1,r,u,v)); } void slove() { cin >> n >> x; m.insert(-500); for (int i=1;i<=n;i++) { cin >> a[i]; d[i]=2e9+5; m.insert(a[i]); c[i].pb(0); } for (int i: m) b.pb(i); m.clear(); for (int i=1;i<=n;i++) { int vt=lower_bound(d+1,d+1+n,a[i])-d; d[vt]=a[i]; t[i]=vt; } for (int i=1;i<=n;i++) d[i]=2e9+5; for (int i=n;i>=1;i--) { int vt=lower_bound(d+1,d+1+n,-a[i])-d; d[vt]=-a[i]; s[i]=vt; int tv=lower_bound(b.begin(),b.end(),a[i])-b.begin(); c[tv].pb(vt); m.insert(tv); } b.pb(2e9+5); for (int i=1;i<=n;i++) cnt[i]=c[i].size()-1; for (int i: m) { for (int j=0;j<c[i].size();j++) { if (j==0) continue; c[i][j]=max(c[i][j],c[i][j-1]); } } build(1,1,n); int ans=0; for (int i=1;i<=n;i++) { int vt=lower_bound(b.begin(),b.end(),a[i])-b.begin(); cnt[vt]--; up(1,1,n,vt,c[vt][cnt[vt]]); vt=upper_bound(b.begin(),b.end(),a[i]-x)-b.begin(); ans=max(ans,get(1,1,n,vt,n) + t[i]); } cout << ans; } int main() { //freopen("test.inp","r",stdin); //freopen("test.out","w",stdout); ios_base::sync_with_stdio(0); cout.tie(0); cin.tie(0); int T=1; //cin >> T; while(T--) slove(); }

Compilation message (stderr)

glo.cpp: In function 'void slove()':
glo.cpp:93:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   93 |         for (int j=0;j<c[i].size();j++)
      |                      ~^~~~~~~~~~~~
#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...