173132025-06-22 22:28:11akososkaA lehető legkevesebb átszállás (50 pont)cpp17Accepted 50/508ms508 KiB
#include <bits/stdc++.h>

using namespace std;
struct bencu{
    int elso;
    int masod;
}a[10001];

int main()
{
    int n,m,utolso=1,p=0,b[10001],hely=1,shely=1;
    cin>>n;
    cin>>m;
    for(int i=1;i<=n;i++){
        cin>>a[i].elso;
        cin>>a[i].masod;
    }
    if(a[1].elso!=1){
        cout<<-1;
        return 0;
    }
    int i=1;
    while(i<=n && utolso<m){
        if(utolso>=a[i].elso){
            if(a[i].masod>shely){
                shely=a[i].masod;
                hely=i;
            }
            i++;
        }
        else{
            utolso=shely;
            p++;
            b[p]=hely;
            if(a[i].masod>shely && a[i].elso<=utolso){
                shely=a[i].masod;
                hely=i;
            }
            i++;

        }
    }
    if(utolso!=shely){
        utolso=shely;
        p++;
        b[p]=hely;
    }
    if(utolso==m){
        cout<<p-1<<endl;
        for(int j=1;j<=p;j++){
        cout<<b[j]<<" ";
        }
    }
    else cout<<-1;
    return 0;
}
SubtaskSumTestVerdictTimeMemory
base50/50
1Accepted0/01ms316 KiB
2Accepted0/07ms476 KiB
3Accepted1/11ms500 KiB
4Accepted1/11ms316 KiB
5Accepted2/21ms316 KiB
6Accepted2/21ms316 KiB
7Accepted2/21ms316 KiB
8Accepted2/22ms316 KiB
9Accepted2/22ms416 KiB
10Accepted2/23ms316 KiB
11Accepted2/23ms316 KiB
12Accepted2/24ms508 KiB
13Accepted2/22ms508 KiB
14Accepted2/22ms508 KiB
15Accepted2/23ms316 KiB
16Accepted2/24ms392 KiB
17Accepted2/24ms448 KiB
18Accepted2/26ms316 KiB
19Accepted2/27ms508 KiB
20Accepted2/26ms316 KiB
21Accepted2/28ms508 KiB
22Accepted2/27ms508 KiB
23Accepted2/27ms316 KiB
24Accepted2/27ms484 KiB
25Accepted2/27ms316 KiB
26Accepted2/27ms316 KiB
27Accepted2/27ms316 KiB
28Accepted2/27ms508 KiB