Submission #360126

#TimeUsernameProblemLanguageResultExecution timeMemory
360126MlxaBalanced Tree (info1cup18_balancedtree)C++14
0 / 100
388 ms18408 KiB
#ifdef LC #include "pch.h" #else #include <bits/stdc++.h> #endif using namespace std; using ll = long long; #define int ll #define all(x) x.begin(), x.end() #define x first #define y second #define mp make_pair #define mt make_tuple const int N = 1e5 + 10; int n; vector<int> g[N]; int c[N]; int dist[N]; int check(int value) { queue<int> q; fill_n(dist, n, N); for (int i = 0; i < n; ++i) { if (c[i] == value) { dist[i] = 0; q.push(i); } } if (q.empty()) { return 0; } while (q.size()) { int v = q.front(); q.pop(); for (int u : g[v]) { if (dist[u] > dist[v] + 1) { dist[u] = dist[v] + 1; q.push(u); } } } int answer = 0; for (int i = 0; i < n; ++i) { for (int j : g[i]) { answer = max(answer, dist[i] + 1 + dist[j]); } } return answer; } void solve() { cin >> n; fill_n(g, n, vector<int>()); for (int v, u, i = 0; i < n - 1; ++i) { cin >> v >> u; --v, --u; g[v].push_back(u); g[u].push_back(v); } for (int i = 0; i < n; ++i) { cin >> c[i]; } cout << max(check(0), check(1)) << "\n"; for (int i = 0; i < n; ++i) { cout << c[i] << " "; } cout << "\n"; } signed main() { #ifdef LC assert(freopen("input.txt", "r", stdin)); #endif ios::sync_with_stdio(0); cin.tie(0); int tn; cin >> tn; while (tn--) { solve(); } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...