제출 #348788

#제출 시각아이디문제언어결과실행 시간메모리
348788Sprdalo선물상자 (IOI15_boxes)C++17
100 / 100
703 ms382816 KiB
#include <bits/stdc++.h>

using namespace std;

typedef long long ll;
typedef long double ld;
typedef pair<int, int> pi;
typedef pair<ll, ll> pl;
typedef vector<int> vi;
typedef vector<ll> vl;
typedef vector<double> vd;
typedef vector<bool> vb;
typedef vector<char> vc;
typedef vector<string> vs;
typedef vector<pi> vp;
typedef vector<pl> vpl;

ll delivery(int n, int k, int l, int positions[]){
    vi a;
    for (int i = 0; i < n; ++i)
        if (positions[i])
            a.push_back(positions[i]);
    n = a.size();

    vl dp(n,0);
    for (int i = 0; i < n; ++i){
        if (i < k)
            dp[i] = min(2 * a[i], l);
        else
            dp[i] = min(2 * a[i], l) + dp[i-k];
    }

    vl dpc(n, 0);
    for (int i = n - 1; i > -1; --i){
        if (i > n-k-1)
            dpc[i] = min(2*(l-a[i]), l);
        else
            dpc[i] = min(2*(l-a[i]), l) + dpc[i+k];
    }
    dpc.push_back(0);

    ll sol = min(dp[n-1], dpc[0]);
    for (int i = 0; i < n; ++i){
        sol = min(sol, dp[i] + dpc[i+1]);
    }

    for (int i = 0; i < n; ++i){
        sol = min(sol, dp[i] + l + dpc[min(n,i+k+1)]);
    }

    return sol;
}
/*
int main()
{
    ios_base::sync_with_stdio(false); 
    cin.tie(nullptr); 
    cout.tie(nullptr); 
    cerr.tie(nullptr);    

    int n, k, l;
    cin >> n >> k >> l;

    int positions[n];
    for (int i = 0; i < n; ++i)
        cin >> positions[i];

    cout << delivery(n,k,l,positions) << '\n';
}*/

컴파일 시 표준 에러 (stderr) 메시지

boxes.cpp: In function 'll delivery(int, int, int, int*)':
boxes.cpp:23:15: warning: conversion from 'std::vector<int>::size_type' {aka 'long unsigned int'} to 'int' may change value [-Wconversion]
   23 |     n = a.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...