Submission #260770

#TimeUsernameProblemLanguageResultExecution timeMemory
260770ElyesChaabouniBoxes with souvenirs (IOI15_boxes)C++14
0 / 100
1 ms384 KiB
/*#pragma GCC optimize("O3")*/ #include<bits/stdc++.h> //#include <ext/pb_ds/assoc_container.hpp> //#include <ext/pb_ds/tree_policy.hpp> //#define ordered_set tree<int, null_type,less<int >, rb_tree_tag,tree_order_statistics_node_update> #define eps 1e-9 #define MOD1 998244353 #define MOD2 1000000007 #define INV_10 299473306 #define INF 1000000001 #define PI 3.14159265358979323846 using namespace std; long long delivery(int N, int K, int L, int p[]) { long long pr1[N+2], pr2[N+2], ans=0; pr1[0]=0; pr2[N+1]=0; for(int i = 1; i <= N; i++) pr1[i]=pr1[i-1]+p[i-1]; for(int i=N; i >= 1; i--) pr2[i]=pr2[i+1]+p[i-1]; int l=1, r=N; while(l <= r) { long long x=pr1[min(r, l+K-1)]-pr1[l-1], y=pr2[max(l, r-K+1)]-pr2[r+1], d=L; if(x <= y) l=min(r, l+K-1)+1; else r=max(l, r-K+1)-1; ans+=min(min(2*x, 2*y), d); } return ans; } //size
#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...