5708 2023. 09. 09 18:14:19 TomaSajt Elágazás nélküli úton levő települések (50 pont) cpp17 Elfogadva 50/50 14ms 5956 KiB
#include <bits/stdc++.h>
using namespace std;

set<int> sol;
vector<vector<int>> g;

void dfs(int u, int p) {
  for (int v : g[u]) {
    if (v == p) continue;
    sol.insert(v);
    if (g[v].size() >= 3) continue;
    dfs(v, u);
  }
}
int main() {
  cin.tie(0), ios::sync_with_stdio(0);

  int n, m;
  cin >> n >> m;
  g.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);
  }

  cout << sol.size() << '\n';
  for (int i : sol) cout << i << ' ';
}
Részfeladat Összpont Teszt Verdikt Idő Memória
base 50/50
1 Elfogadva 0/0 3ms 2168 KiB
2 Elfogadva 0/0 14ms 4228 KiB
3 Elfogadva 2/2 3ms 2592 KiB
4 Elfogadva 2/2 3ms 2644 KiB
5 Elfogadva 2/2 3ms 2856 KiB
6 Elfogadva 2/2 2ms 3064 KiB
7 Elfogadva 2/2 3ms 3204 KiB
8 Elfogadva 2/2 3ms 3636 KiB
9 Elfogadva 2/2 4ms 4056 KiB
10 Elfogadva 2/2 6ms 4208 KiB
11 Elfogadva 2/2 8ms 4524 KiB
12 Elfogadva 2/2 8ms 4836 KiB
13 Elfogadva 3/3 3ms 3984 KiB
14 Elfogadva 3/3 4ms 4236 KiB
15 Elfogadva 3/3 4ms 4352 KiB
16 Elfogadva 3/3 4ms 4660 KiB
17 Elfogadva 3/3 8ms 5156 KiB
18 Elfogadva 3/3 8ms 5148 KiB
19 Elfogadva 3/3 9ms 5424 KiB
20 Elfogadva 3/3 14ms 5584 KiB
21 Elfogadva 3/3 14ms 5900 KiB
22 Elfogadva 3/3 14ms 5956 KiB