236312026-01-26 17:36:14algoproBenzinkút üzemeltetés (55)cpp17Hibás válasz 0/554ms2868 KiB
// UUID: 80fedc39-61ff-49d8-baeb-030fd71a6e28
#include <bits/stdc++.h>
using namespace std;

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

	vector<pair<long long, long long>> tavolsag(n + 1);

	for(int i=1;i <= n; i++){
		cin >> tavolsag[i].first >> tavolsag[i].second;
	}

	tavolsag[0].first = tavolsag[1].second;
	tavolsag[1].second = 0;
	vector<long long> dp(n+1);
	vector<vector<long long>> ans(n+1);
	dp[0] = 0;
	for(int i = 1; i <= n; i++){
		for(int j = i - 1; j > -1; j--){
			if(tavolsag[i].first - tavolsag[j].first >= k){
				dp[i] = max(dp[i - 1], dp[j] + tavolsag[i].second);
				if(dp[i - 1] < dp[j] + tavolsag[i].second){
					ans[i] = ans[j];
					ans[i].push_back(i);
				}
				else ans[i] = ans[i - 1];
				break;
			}
		}
	}
	cout << dp[n] << "\n" << ans[n].size();
	for(int x : ans[n]){
		cout << " " << x;
	}
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base0/55
1Hibás válasz0/01ms500 KiB
2Hibás válasz0/04ms2868 KiB
3Hibás válasz0/31ms316 KiB
4Hibás válasz0/31ms316 KiB
5Hibás válasz0/31ms316 KiB
6Hibás válasz0/31ms316 KiB
7Hibás válasz0/31ms316 KiB
8Hibás válasz0/31ms316 KiB
9Hibás válasz0/31ms316 KiB
10Hibás válasz0/31ms316 KiB
11Hibás válasz0/31ms316 KiB
12Hibás válasz0/32ms820 KiB
13Hibás válasz0/43ms1332 KiB
14Hibás válasz0/42ms1588 KiB
15Hibás válasz0/53ms1844 KiB
16Hibás válasz0/63ms2356 KiB
17Hibás válasz0/63ms2612 KiB