제출 #107192

#제출 시각아이디문제언어결과실행 시간메모리
107192dolphingarlicNetwork (BOI15_net)C++17
0 / 100
16 ms12160 KiB
#include <bits/stdc++.h> #pragma GCC optimize("O3") #define FOR(i, x, y) for(ll i = x; i < y; i++) typedef long long ll; using namespace std; vector<ll> graph[500001], leaves; void dfs(ll node, ll parent = 0) { if (graph[node].size() == 1) leaves.push_back(node); for (auto& i : graph[node]) { if (i == parent) continue; dfs(i, node); } } int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); ll n; cin >> n; FOR(i, 0, n - 1) { ll a, b; cin >> a >> b; graph[a].push_back(b); graph[b].push_back(a); } dfs(1); cout << (leaves.size() + 1) / 2 << '\n'; FOR(i, 0, (ll)(leaves.size() / 2)) cout << leaves[i] << ' ' << leaves[leaves.size() - i - 1] << '\n'; if (leaves.size() & 1) cout << leaves[leaves.size() / 2] << " 1\n"; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...