4531 2023. 03. 29 12:51:16 TomaSajt Elágazás nélküli úton levő települések (50 pont) cpp17 Elfogadva 50/50 14ms 6336 KiB
#include <bits/stdc++.h>
using namespace std;
#define speed cin.tie(0); ios::sync_with_stdio(0)

set<int> sol;
vector<int> vis;
vector<vector<int>> g;
int t = 1;

void dfs(int u, int p) {
    for (int v : g[u]) {
        if (v == p || vis[v] == t) continue;
        sol.insert(v);
        if (g[v].size() > 2) continue;
        dfs(v, u);
    }
}

int main() {
    speed;
    int n, m; cin >> n >> m;
    g.resize(n + 1);
    vis.resize(n + 1);
    while (m--) {
        int u, v; cin >> u >> v;
        g[u].push_back(v);
        g[v].push_back(u);
    }
    for (int i = 1; i <= n; i++) {
        if (g[i].size() == 1) {
            dfs(i, 0);
        }
        t++;
    }
    cout << sol.size() << '\n';
    for (auto i : sol) cout << i << ' ';
    return 0;
}
Részfeladat Összpont Teszt Verdikt Idő Memória
base 50/50
1 Elfogadva 0/0 3ms 1888 KiB
2 Elfogadva 0/0 14ms 3972 KiB
3 Elfogadva 2/2 2ms 2332 KiB
4 Elfogadva 2/2 2ms 2508 KiB
5 Elfogadva 2/2 2ms 2620 KiB
6 Elfogadva 2/2 3ms 2740 KiB
7 Elfogadva 2/2 3ms 2944 KiB
8 Elfogadva 2/2 3ms 3384 KiB
9 Elfogadva 2/2 4ms 3800 KiB
10 Elfogadva 2/2 4ms 4084 KiB
11 Elfogadva 2/2 8ms 4636 KiB
12 Elfogadva 2/2 8ms 4688 KiB
13 Elfogadva 3/3 3ms 3740 KiB
14 Elfogadva 3/3 4ms 4096 KiB
15 Elfogadva 3/3 4ms 4504 KiB
16 Elfogadva 3/3 4ms 4836 KiB
17 Elfogadva 3/3 7ms 4968 KiB
18 Elfogadva 3/3 8ms 5248 KiB
19 Elfogadva 3/3 8ms 5488 KiB
20 Elfogadva 3/3 13ms 6036 KiB
21 Elfogadva 3/3 14ms 6336 KiB
22 Elfogadva 3/3 14ms 6292 KiB