140652025-01-09 18:07:19MatematikaBenzinkút üzemeltetés (55)cpp17Wrong answer 0/552ms532 KiB
#include <bits/stdc++.h>
using namespace std;
using ll=long long;

int main()
{
    ios::sync_with_stdio(false); cin.tie(0);
    int n,k,ki=0,ideal=0; cin >> n >> k;
    vector<int> vec(n),haszon(n),dp(n),p(n);
    for(int i=0; i<n; i++)
        cin >> vec[i] >> haszon[i];
    for(int i=0; i<n; i++)
    {
        dp[i]=haszon[i];
        for(int j=0; j<i; j++)
        {
            if(vec[j]+k<=vec[i])
            {
                if(dp[j]+haszon[i]>dp[i])
                {
                    dp[i]=dp[j]+haszon[i];
                    p[i]=j;
                }
            }
        }
    }
    for(int i=0; i<n; i++)
    {
        if(dp[i]>ki)
        {
            ki=dp[i];
            ideal=i;
        }
    }
    cout << ki << "\n";
    vec.resize(0);
    for(int i=ideal; i!=0; i=p[i])
        vec.push_back(i);
    reverse(vec.begin(),vec.end());
    for(auto z:vec)
        cout << z+1 << " ";
    return 0;
}
SubtaskSumTestVerdictTimeMemory
base0/55
1Wrong answer0/01ms316 KiB
2Wrong answer0/02ms316 KiB
3Wrong answer0/31ms316 KiB
4Wrong answer0/31ms316 KiB
5Wrong answer0/31ms316 KiB
6Wrong answer0/31ms504 KiB
7Wrong answer0/31ms316 KiB
8Wrong answer0/31ms316 KiB
9Wrong answer0/31ms508 KiB
10Wrong answer0/31ms532 KiB
11Wrong answer0/31ms316 KiB
12Wrong answer0/31ms316 KiB
13Wrong answer0/41ms316 KiB
14Wrong answer0/41ms316 KiB
15Wrong answer0/51ms316 KiB
16Wrong answer0/62ms316 KiB
17Wrong answer0/62ms316 KiB