6935 2023. 12. 20 18:53:58 MagyarKendeSZLG A lehető legkevesebb átszállás (50 pont) cpp17 Elfogadva 50/50 4ms 4832 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 1832 KiB
2 Elfogadva 0/0 4ms 2232 KiB
3 Elfogadva 1/1 3ms 2444 KiB
4 Elfogadva 1/1 3ms 2500 KiB
5 Elfogadva 2/2 3ms 2644 KiB
6 Elfogadva 2/2 3ms 2848 KiB
7 Elfogadva 2/2 3ms 3076 KiB
8 Elfogadva 2/2 3ms 3408 KiB
9 Elfogadva 2/2 3ms 3612 KiB
10 Elfogadva 2/2 3ms 3708 KiB
11 Elfogadva 2/2 4ms 3588 KiB
12 Elfogadva 2/2 4ms 3600 KiB
13 Elfogadva 2/2 3ms 3752 KiB
14 Elfogadva 2/2 3ms 3848 KiB
15 Elfogadva 2/2 3ms 4176 KiB
16 Elfogadva 2/2 4ms 4464 KiB
17 Elfogadva 2/2 4ms 4596 KiB
18 Elfogadva 2/2 4ms 4600 KiB
19 Elfogadva 2/2 4ms 4832 KiB
20 Elfogadva 2/2 4ms 4628 KiB
21 Elfogadva 2/2 4ms 4644 KiB
22 Elfogadva 2/2 4ms 4640 KiB
23 Elfogadva 2/2 4ms 4636 KiB
24 Elfogadva 2/2 4ms 4636 KiB
25 Elfogadva 2/2 4ms 4636 KiB
26 Elfogadva 2/2 4ms 4644 KiB
27 Elfogadva 2/2 4ms 4652 KiB
28 Elfogadva 2/2 4ms 4644 KiB