123452024-12-12 20:20:52AblablablaBenzinkút üzemeltetés (55)cpp17Accepted 55/5529ms8540 KiB
#include <bits/stdc++.h>

using namespace std;

typedef long long ll;

ll n, k;
vector<ll> hely, ertek;
vector<vector<ll>> dp;
vector<vector<bool>> irany;

ll megold(ll ind, ll elozo){
    if(ind > n){
        return 0;
    }
    if(dp[ind][elozo] != -1){
        return dp[ind][elozo];
    }

    ll a = megold(ind + 1, elozo), b = -1;
    if(hely[elozo] + k <= hely[ind]){
        b = megold(ind + 1, ind) + ertek[ind];
    }

    if(a <= b){
        irany[ind][elozo] = 1;
    }

    return dp[ind][elozo] = max(a, b);
}

int main()
{
    cin >> n >> k;

    hely.assign(n + 1, 0);
    ertek.assign(n + 1, 0);
    hely[0] = -1e9;
    for(ll i = 1; i <= n; i++){
        cin >> hely[i] >> ertek[i];
    }

    dp.assign(n + 1, vector<ll>(n + 1, -1));
    irany.assign(n + 1, vector<bool>(n + 1, 0));

    cout << megold(1, 0) << "\n";

    vector<ll> ans;
    ll egy = 1, ket = 0;
    while(egy <= n && ket <= n){
        if(ket >= egy){
            cout << egy << " " << ket << "\n";
        }
        assert(ket < egy);
        if(irany[egy][ket]){
            ans.push_back(egy);
            ket = egy;
            egy++;
        } else{
            egy++;
        }
    }

    cout << ans.size() << " ";
    for(ll x : ans) cout << x << " ";
    cout << "\n";
}
SubtaskSumTestVerdictTimeMemory
base55/55
1Accepted0/01ms320 KiB
2Accepted0/028ms8504 KiB
3Accepted3/31ms320 KiB
4Accepted3/31ms320 KiB
5Accepted3/31ms320 KiB
6Accepted3/31ms320 KiB
7Accepted3/31ms320 KiB
8Accepted3/31ms320 KiB
9Accepted3/31ms320 KiB
10Accepted3/31ms320 KiB
11Accepted3/31ms568 KiB
12Accepted3/38ms2284 KiB
13Accepted4/410ms3380 KiB
14Accepted4/413ms4428 KiB
15Accepted5/517ms5640 KiB
16Accepted6/620ms6836 KiB
17Accepted6/629ms8540 KiB