138002025-01-08 18:53:38csdavidElágazás nélküli úton levő települések (50 pont)cpp17Accepted 50/5027ms1324 KiB
#include <iostream>
#include <vector>
#include <stack>
//#include <fstream>
using namespace std;

struct telepules{
    vector<int> ut;
    int o=0;
    bool bejart=0, megoldas=0;
};

int main()
{
    //ifstream fin("be2.txt");
    stack<int> q;
    int n, m, x, y;
    cin >> n >> m;
    telepules a[n];
    for(int i=0; i<m; i++){
        cin >> x >> y;
        --x;
        --y;
        a[x].ut.push_back(y);
        a[x].o++;
        a[y].ut.push_back(x);
        a[y].o++;
    }
    y=0;
    for(int i=0; i<n; i++){
        if(a[i].o==1){
            q.push(i);
        }
    }
    int eredeti;
    while(!q.empty()){
        x=q.top();
        eredeti=x;
        a[x].bejart=1;
        q.push(a[x].ut[0]);
        while(q.top()!=eredeti){
            y=q.top();
            q.pop();
            a[y].megoldas=1;
            a[y].bejart=1;
            if(a[y].o==2){
                if(!a[a[y].ut[0]].bejart){
                    q.push(a[y].ut[0]);
                }
                else if(!a[a[y].ut[1]].bejart){
                    q.push(a[y].ut[1]);
                }
            }
            else if(a[y].o==1){
                a[eredeti].megoldas=1;
                break;
            }
            else{
                break;
            }
        }
        q.pop();
    }
    x=0;
    for(int i=0; i<n; i++){
        if(a[i].megoldas){
            x++;
        }
    }
    cout << x << '\n';
    for(int i=0; i<n; i++){
        if(a[i].megoldas){
            cout << i+1 << ' ';
        }
    }
    return 0;
}
SubtaskSumTestVerdictTimeMemory
base50/50
1Accepted0/01ms316 KiB
2Accepted0/027ms1324 KiB
3Accepted2/21ms316 KiB
4Accepted2/21ms316 KiB
5Accepted2/21ms316 KiB
6Accepted2/21ms316 KiB
7Accepted2/21ms316 KiB
8Accepted2/23ms456 KiB
9Accepted2/24ms564 KiB
10Accepted2/27ms564 KiB
11Accepted2/213ms784 KiB
12Accepted2/214ms868 KiB
13Accepted3/32ms316 KiB
14Accepted3/33ms380 KiB
15Accepted3/34ms756 KiB
16Accepted3/34ms564 KiB
17Accepted3/312ms808 KiB
18Accepted3/313ms832 KiB
19Accepted3/314ms1076 KiB
20Accepted3/326ms1244 KiB
21Accepted3/327ms1160 KiB
22Accepted3/326ms1188 KiB