Submission #41722

#TimeUsernameProblemLanguageResultExecution timeMemory
41722funcsrBoxes with souvenirs (IOI15_boxes)C++14
100 / 100
557 ms141304 KiB
#include "boxes.h" #include <iostream> #include <vector> #include <algorithm> #include <string> #include <queue> #include <cassert> using namespace std; #define rep(i, n) for (int i=0; i<(n); i++) #define all(x) x.begin(), x.end() #define uniq(x) x.erase(unique(all(x)), x.end()) #define index(x, y) (int)(lower_bound(all(x), y) - x.begin()) #define pb push_back #define _1 first #define _2 second #define INF (1LL<<60) typedef pair<int, int> P; int A[10000000], B[10000000]; int HA[10000000], HB[10000000]; long long SA[10000000], SB[10000000]; long long delivery(int N, int K, int L, int X[]) { //rep(i, N) cout << X[i]<<",";cout<<"\n"; rep(i, N) A[i] = min(2LL*X[i], (long long)L); rep(i, N) B[i] = min(2LL*(L-X[i]), (long long)L); rep(i, N) SB[i%K] += B[i]; long long m = INF; rep(i, N+1) { long long s = SB[i%K]; if (i > 0) { int k = (i-1)%K; while (HA[k]*K+k <= i-1) SA[k] += A[HA[k]*K+k], HA[k]++; s += SA[k]; } //for (int x=i-1; x>=0; x-=K) s += A[x]; m = min(m, s); if (i < N) { int k = i%K; while (HB[k]*K+k <= i) SB[k] -= B[HB[k]*K+k], HB[k]++; } } return m; }

Compilation message (stderr)

boxes.cpp: In function 'long long int delivery(int, int, int, int*)':
boxes.cpp:24:23: warning: conversion to 'int' from 'long long int' may alter its value [-Wconversion]
   rep(i, N) A[i] = min(2LL*X[i], (long long)L);
                    ~~~^~~~~~~~~~~~~~~~~~~~~~~~
boxes.cpp:25:23: warning: conversion to 'int' from 'long long int' may alter its value [-Wconversion]
   rep(i, N) B[i] = min(2LL*(L-X[i]), (long long)L);
                    ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
#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...