156172025-02-21 09:42:10MatematikaFertőzési sorozat (50 pont)cpp17Hibás válasz 0/501ms508 KiB
#include <bits/stdc++.h>

using namespace std;

vector<vector<int>> vec;
vector<bool> kas;
vector<int> erdos,ki;
int e=0;

void dfs(int x)
{
    e++;
    erdos[x]=e;
    for(auto& z:vec[x])
        if(erdos[z]>e+1)
            dfs(z);
    e--;
}

int main()
{
    ios::sync_with_stdio(false); cin.tie(0);
    int n,m,k; cin >> n >> m >> k;
    vec.resize(n);
    kas.resize(n);
    erdos.resize(n);
    vector<int> be(k);
    for(auto& z:be)
    {
        cin >> z;
        z--;
        kas[z]=true;
    }
    for(int i=0; i<m; i++)
    {
        int a,b; cin >> a >> b;
        vec[a-1].push_back(b-1);
        vec[b-1].push_back(a-1);
    }
    for(int i=0; i<n; i++)
    {
        if(kas[i] && i!=be[0])
            continue;
        erdos.assign(n,LONG_MAX);
        dfs(i);
        /*for(auto z:erdos)
            cerr << z << " ";*/
        /*if(i==3)
            for(auto z:erdos)
                cerr << z << " ";*/
        int elozo=be[0];
        bool berak=true;
        for(auto& z:be)
        {
            if(erdos[z]!=erdos[elozo] && erdos[elozo]+1!=erdos[z])
            {
                berak=false;
                break;
            }
            elozo=z;
        }
        /*for(int i=0; i<n; i++)
            if(!kas[i] && (erdos[i]<erdos[be[0]] || erdos[i]>erdos[be.back()]))
                berak=false;*/
        if(berak)
            ki.push_back(i);
    }
    cout << ki.size() << "\n";
    for(auto z:ki)
        cout << z+1 << " ";
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base0/50
1Elfogadva0/01ms500 KiB
2Hibás válasz0/01ms316 KiB
3Hibás válasz0/01ms496 KiB
4Hibás válasz0/21ms316 KiB
5Hibás válasz0/21ms316 KiB
6Hibás válasz0/21ms508 KiB
7Hibás válasz0/21ms316 KiB
8Hibás válasz0/21ms316 KiB
9Hibás válasz0/21ms316 KiB
10Hibás válasz0/21ms436 KiB
11Hibás válasz0/11ms316 KiB
12Hibás válasz0/21ms316 KiB
13Hibás válasz0/21ms316 KiB
14Hibás válasz0/21ms316 KiB
15Hibás válasz0/21ms316 KiB
16Hibás válasz0/21ms456 KiB
17Hibás válasz0/21ms316 KiB
18Hibás válasz0/11ms316 KiB
19Hibás válasz0/11ms316 KiB
20Hibás válasz0/11ms316 KiB
21Hibás válasz0/11ms316 KiB
22Hibás válasz0/11ms316 KiB
23Hibás válasz0/11ms316 KiB
24Hibás válasz0/11ms316 KiB
25Hibás válasz0/11ms316 KiB
26Hibás válasz0/11ms316 KiB
27Hibás válasz0/11ms316 KiB
28Hibás válasz0/11ms316 KiB
29Hibás válasz0/11ms316 KiB
30Hibás válasz0/11ms316 KiB
31Hibás válasz0/11ms316 KiB
32Hibás válasz0/11ms316 KiB
33Hibás válasz0/11ms316 KiB
34Hibás válasz0/11ms316 KiB
35Hibás válasz0/11ms316 KiB
36Hibás válasz0/11ms316 KiB
37Hibás válasz0/11ms452 KiB
38Hibás válasz0/11ms404 KiB
39Hibás válasz0/11ms444 KiB
40Hibás válasz0/11ms316 KiB