6936 2023. 12. 20 18:54:06 MagyarKendeSZLG A lehető legkevesebb átszállás (50 pont) cpp17 Elfogadva 50/50 4ms 4836 KiB
#include <iostream>
#include <vector>
#include <array>
#include <queue>

using namespace std;

using Pair = array<int, 2>;

void init() {
    cin.tie(nullptr);
    cout.tie(nullptr);
    ios::sync_with_stdio(0);
}

int main() {
    init();

    int N, M;
    cin >> N >> M;

    vector<Pair> TS(N + 1);
    for (int i = 1; i <= N; i++) {
        cin >> TS[i][0] >> TS[i][1];
    }

    vector<int> path;
    int i = 1, pos = 1, curr;

    while (pos < M) {
        curr = -1;

        while (i <= N && TS[i][0] <= pos) {
            if (curr == -1 || TS[curr][1] < TS[i][1]) curr = i;
            i++;
        }

        if (curr == -1) { // impossible part
            cout << -1;
            exit(0);
        }

        pos = TS[curr][1];
        path.push_back(curr);
    }

    cout << path.size() - 1 << '\n';
    for (int n : path)  {
        cout << n << ' ';
    }

    return 0;
}
Részfeladat Összpont Teszt Verdikt Idő Memória
base 50/50
1 Elfogadva 0/0 3ms 2108 KiB
2 Elfogadva 0/0 4ms 2348 KiB
3 Elfogadva 1/1 3ms 2192 KiB
4 Elfogadva 1/1 3ms 2240 KiB
5 Elfogadva 2/2 3ms 2480 KiB
6 Elfogadva 2/2 3ms 2684 KiB
7 Elfogadva 2/2 3ms 2804 KiB
8 Elfogadva 2/2 3ms 2764 KiB
9 Elfogadva 2/2 3ms 3028 KiB
10 Elfogadva 2/2 3ms 2980 KiB
11 Elfogadva 2/2 3ms 2984 KiB
12 Elfogadva 2/2 4ms 3144 KiB
13 Elfogadva 2/2 3ms 2960 KiB
14 Elfogadva 2/2 3ms 3060 KiB
15 Elfogadva 2/2 3ms 3236 KiB
16 Elfogadva 2/2 4ms 3324 KiB
17 Elfogadva 2/2 4ms 3612 KiB
18 Elfogadva 2/2 4ms 3368 KiB
19 Elfogadva 2/2 4ms 3640 KiB
20 Elfogadva 2/2 4ms 3856 KiB
21 Elfogadva 2/2 4ms 3944 KiB
22 Elfogadva 2/2 4ms 4224 KiB
23 Elfogadva 2/2 4ms 4164 KiB
24 Elfogadva 2/2 4ms 4184 KiB
25 Elfogadva 2/2 4ms 4412 KiB
26 Elfogadva 2/2 4ms 4624 KiB
27 Elfogadva 2/2 4ms 4836 KiB
28 Elfogadva 2/2 4ms 4796 KiB