219312026-01-14 10:39:22RRoliA lehető legkevesebb átszállás (50 pont)cpp17Accepted 50/509ms1188 KiB
#include <bits/stdc++.h>
using namespace std;

int n, m, a[100001][2], ki[100001];
bool joe;

int main() {
	cin >> n >> m;
	for(int i = 1; i <= m; i++) {
		int e, u;
		cin >> e >> u;
		if(a[e][0] < u) {
			a[e][0] = u;
			a[e][1] = i;
		}
	}

	int sz = 0, ugras = a[1][0], max_ert = 0, max_ind = 0;
	ki[0] = a[1][1];
	for(int i = 1; i <= m && !joe; i++) {
		if(i > ugras) {
			if(max_ert == 0) {
				cout << -1;
				joe = true;
			}
			sz++;
			ki[sz] = max_ind;
			ugras = max_ert;
			max_ert = 0;
		}
		if(a[i][0] > max_ert) {
			max_ert = a[i][0];
			max_ind = a[i][1];
		}
	}
    
    if(ugras < m) cout << -1;
    else if(!joe) {
    	cout << sz << '\n';
		for(int i = 0; i <= sz; i++) cout << ki[i] << ' '; 
    }

	return 0;
}
SubtaskSumTestVerdictTimeMemory
base50/50
1Accepted0/01ms316 KiB
2Accepted0/09ms1076 KiB
3Accepted1/11ms316 KiB
4Accepted1/11ms500 KiB
5Accepted2/21ms332 KiB
6Accepted2/21ms316 KiB
7Accepted2/22ms500 KiB
8Accepted2/22ms316 KiB
9Accepted2/22ms436 KiB
10Accepted2/23ms316 KiB
11Accepted2/24ms668 KiB
12Accepted2/24ms592 KiB
13Accepted2/22ms564 KiB
14Accepted2/24ms560 KiB
15Accepted2/24ms564 KiB
16Accepted2/24ms564 KiB
17Accepted2/28ms1076 KiB
18Accepted2/28ms872 KiB
19Accepted2/28ms1080 KiB
20Accepted2/28ms1188 KiB
21Accepted2/29ms1108 KiB
22Accepted2/29ms1184 KiB
23Accepted2/28ms448 KiB
24Accepted2/28ms484 KiB
25Accepted2/28ms316 KiB
26Accepted2/28ms516 KiB
27Accepted2/28ms516 KiB
28Accepted2/28ms316 KiB