Submission #1129959

#TimeUsernameProblemLanguageResultExecution timeMemory
1129959SofiatpcRice Hub (IOI11_ricehub)C++20
17 / 100
0 ms328 KiB
#include "ricehub.h" #include <bits/stdc++.h> using namespace std; typedef long long ll; const int INF = 1e9+5; int besthub(int n, int L, int x[], ll b) { int ans = 0, r = 0, cur = 0, m = x[0], qtd = 1; for(int l = 0; l < n; l++){ if(l > r){ r = l; cur = 0; m = x[r]; qtd = 1; } //cerr<<l<<": "; while(r < n){ r++; int nxtm; if((r-l+1)%2 == 1)nxtm = x[l+(r-l+1)/2]; else nxtm = (x[l+(r-l+1)/2-1] + x[l+(r-l+1)/2])/2; int nxtqtd = qtd; if((r-l+1)%2 == 1)nxtqtd++; int nxt = cur + qtd*(nxtm-m) + abs(x[r]-m) - (r-l+1 - qtd)*(nxtm-m); //cerr<<r<<" "<<nxtm<<" "<<nxtqtd<<" "<<nxt<<" | "; if(nxt > b){r--; break;} cur = nxt; m = nxtm; qtd = nxtqtd; } ans = max(ans, r-l+1); int nxtm; if((r-l)%2 == 1)nxtm = x[l+1+(r-l)/2]; else nxtm = (x[l+1+(r-l)/2-1] + x[l+1+(r-l)/2])/2; int nxtqtd = qtd; if((r-l)%2 == 0)nxtqtd--; cur = cur + qtd*(nxtm-m) - abs(x[l]-nxtm) - (r-l - (qtd-1))*(nxtm-m); //cerr<<" => "<<m<<" "<<nxtm<<" "<<nxtqtd<<" "<<cur<<"\n"; m = nxtm; qtd = nxtqtd; } return ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...