Submission #110031

#TimeUsernameProblemLanguageResultExecution timeMemory
110031CaroLindaBoxes with souvenirs (IOI15_boxes)C++14
100 / 100
1795 ms333184 KiB
#include <bits/stdc++.h> #define lp(i,a,b) for(int i = a ; i < b ; i++) #define ll long long #define ff first #define ss second const int MAXN = 1e7 + 5; const ll inf = 1e9 + 10 ; using namespace std ; //Declaracoes int N , K ; ll L ; int pos[MAXN] ; ll dp1[MAXN] , dp2[MAXN] ; //Funcao principal ll delivery(int n , int k , int l , int positions[] ) { //Globalizacao N = n ; K = k ; L= l * 1LL ; lp(i,0,n) pos[i] = positions[i] ; lp(i,0,n) if( pos[i] == 0 ) pos[i] = inf , N-- ; sort( pos , pos + n ) ; n = N ; lp(i,0,n) { dp1[i] = pos[i] * 2 ; if( i - k >= 0 ) dp1[i] += dp1[i-k] ; } for( int i = n-1 ; i >= 0 ; i-- ) { dp2[i] = ( L - pos[i]) * 2 ; if( i + k < n ) dp2[i] += dp2[i+k] ; } ll best = inf * MAXN ; lp(i,0,n-2) best = min( best , dp1[i] + dp2[i+1] ) ; best = min( best , dp1[n-1] ) ; best = min( best , dp2[0] ) ; lp(i,0,n) { ll x = 0; if( i + k < n ) x = dp2[i+k] ; ll y = 0 ; if( i-1 >= 0 ) y = dp1[i-1] ; best = min( best , y + x + L ) ; } return best ; }
#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...