126942024-12-28 13:02:50GundischBalazsElágazás nélküli úton levő települések (50 pont)cpp17Futási hiba 17/50301ms32000 KiB
#include <iostream>
#include <set>
#include <vector>
using namespace std;

void bejar(int x, set <int> &megold, vector <int> fokszam, int n, vector <int> a){
    int i;
    vector <bool> volt;
    volt.resize(n);
    bool felt = 1;
    volt[x] = 1;
    do{
        i=0;
        while( i<n && (a[x*n+i] == 0 || volt[i] == 1)){
            i ++;
        }
        if(i < n){
        megold.insert(i+1);
        volt[i] = 1;
        x = i;
        }
        else{
            felt=0;
        }
    }while(fokszam[x] == 2 && felt);
}

int main()
{
    vector <int> a;
    int  n, m;
    cin >> n >> m;
    a.resize(n*n);
    int x, y;
    for(int i = 0; i < m; i ++){
        cin >> x >> y;
        x--;
        y--;
        a[x*n+y] = 1;
        a[y*n+x] = 1;
    }
    vector <int> fokszam;
    fokszam.resize(n);
    for(int i = 0 ; i < n; i ++){
        for(int j =  0; j < n; j ++){
            fokszam[i] += a[i*n+j];
        }
    }
    set <int> halmaz;
    for(int i = 0; i < n; i ++){
        if(fokszam[i] == 1){
            bejar(i, halmaz, fokszam,n,a);
        }
    }
    cout << halmaz.size() << endl;
    if(halmaz.size() != 0){
         for(auto i : halmaz)
        cout << i << " ";
    }
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base17/50
1Elfogadva0/01ms320 KiB
2Futási hiba0/032ms32000 KiB
3Elfogadva2/21ms508 KiB
4Elfogadva2/21ms508 KiB
5Elfogadva2/21ms320 KiB
6Elfogadva2/21ms320 KiB
7Elfogadva2/21ms320 KiB
8Elfogadva2/225ms8240 KiB
9Elfogadva2/2136ms31544 KiB
10Futási hiba0/228ms32000 KiB
11Futási hiba0/228ms32000 KiB
12Futási hiba0/228ms32000 KiB
13Elfogadva3/371ms8248 KiB
14Időlimit túllépés0/3301ms31540 KiB
15Futási hiba0/329ms32000 KiB
16Futási hiba0/329ms32000 KiB
17Futási hiba0/328ms32000 KiB
18Futási hiba0/334ms32000 KiB
19Futási hiba0/335ms32000 KiB
20Futási hiba0/328ms32000 KiB
21Futási hiba0/327ms32000 KiB
22Futási hiba0/327ms32000 KiB