Submission #226486

#TimeUsernameProblemLanguageResultExecution timeMemory
226486peuchBoxes with souvenirs (IOI15_boxes)C++17
25 / 100
5 ms384 KiB
#include "boxes.h" #include<bits/stdc++.h> using namespace std; const int MAXN = 1e7; const long long INF = 1e10; #define debug(args...) // fprintf(stderr, args) vector<int> all, maior, menor; int dist[MAXN]; int cnt; long long ans = 0; bool cmp(int a, int b){ return dist[a] < dist[b]; } long long delivery(int N, int K, int L, int p[]) { cnt = N; unsigned long k = (unsigned long)K; for(int i = 0; i < N; i++){ if(p[i] > L / 2) dist[i] = L - p[i]; else dist[i] = p[i]; dist[i] *= 2; all.push_back(i); if(p[i] > L / 2) maior.push_back(i); else menor.push_back(i); } debug("LINE 30 OK!\n"); sort(all.begin(), all.end(), cmp); sort(maior.begin(), maior.end(), cmp); sort(menor.begin(), menor.end(), cmp); while(cnt > 0){ debug("%d\n", cnt); long long maiorSum = (maior.size() != 0) ? dist[maior[maior.size() - 1]] : INF; long long menorSum = (menor.size() != 0) ? dist[menor[menor.size() - 1]] : INF; long long allSum = (all.size() != 0) ? L: INF; for(int i = all.size() - 1; i >= max((int)all.size() - K, 0); i--){ allSum -= dist[all[i]]; } debug("ALL OK\n"); for(int i = maior.size() - 1; i >= max((int)maior.size() - K, 0); i--){ debug("%ul\n", i); maiorSum -= dist[maior[i]]; } debug("MAIOR OK\n"); for(int i = menor.size() - 1; i >= max((int)menor.size() - K, 0); i--){ menorSum -= dist[menor[i]]; } debug("MENOR OK\n"); if(maiorSum <= allSum && maiorSum <= menorSum){ debug("MAIOR\n"); ans += dist[maior[maior.size() - 1]]; for(int i = 0; i < k && !maior.empty(); i++){ all.clear(); maior.pop_back(); cnt--; } } else if(menorSum <= allSum && menorSum <= maiorSum){ debug("MENOR\n"); ans += dist[menor[menor.size() - 1]]; for(int i = 0; i < k && !menor.empty(); i++){ all.clear(); menor.pop_back(); cnt--; } } else{ debug("ALL\n"); ans += L; for(int i = 0; i < k && !all.empty(); i++){ if(p[all[all.size() - 1]] > L / 2) maior.pop_back(); else menor.pop_back(); all.pop_back(); cnt--; } } } return ans; }

Compilation message (stderr)

boxes.cpp: In function 'long long int delivery(int, int, int, int*)':
boxes.cpp:39:26: warning: conversion to 'int' from 'std::vector<int>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
   for(int i = all.size() - 1; i >= max((int)all.size() - K, 0); i--){
               ~~~~~~~~~~~^~~
boxes.cpp:43:28: warning: conversion to 'int' from 'std::vector<int>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
   for(int i = maior.size() - 1; i >= max((int)maior.size() - K, 0); i--){
               ~~~~~~~~~~~~~^~~
boxes.cpp:48:28: warning: conversion to 'int' from 'std::vector<int>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
   for(int i = menor.size() - 1; i >= max((int)menor.size() - K, 0); i--){
               ~~~~~~~~~~~~~^~~
boxes.cpp:55:21: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
    for(int i = 0; i < k && !maior.empty(); i++){
                   ~~^~~
boxes.cpp:64:21: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
    for(int i = 0; i < k && !menor.empty(); i++){
                   ~~^~~
boxes.cpp:73:21: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
    for(int i = 0; i < k && !all.empty(); i++){
                   ~~^~~
#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...