Submission #317130

#TimeUsernameProblemLanguageResultExecution timeMemory
3171308e7Balanced Tree (info1cup18_balancedtree)C++14
0 / 100
4089 ms35440 KiB
#include <iostream> #include <algorithm> #include <utility> #include <vector> #define ll long long #define pii pair<int, int> #define ff first #define ss second #define maxn 500005 using namespace std; const int inf = 8e7; vector<int> adj[maxn]; int c[maxn]; pii val[maxn]; pii dfs(int n, int par) { pii ret = make_pair(inf, inf); for (int v:adj[n]) { if (v != par) { pii res = dfs(v, n); ret.ff = min(ret.ff, res.ff + 1); ret.ss = min(ret.ss, res.ss + 1); } } val[n] = ret; if (c[n]) ret.ss = 0; else ret.ff = 0; return ret; } void dfs2(int n, int par, pii cur) { val[n].ff = min(val[n].ff, cur.ff); val[n].ss = min(val[n].ss, cur.ss); for (int v:adj[n]) { if (v != par) { pii upd = cur; for (int u:adj[n]) { if (u != par && u != v) { upd.ff = min(upd.ff, val[u].ff + 1); upd.ss = min(upd.ss, val[u].ss + 1); } } if (c[n]) { upd.ss = 0; } else { upd.ff = 0; } upd.ff++, upd.ss++; dfs2(v, n, upd); } } } int main() { ios_base::sync_with_stdio(0);cin.tie(0); int t; cin >> t; while (t--) { int n; cin >> n; for (int i = 1;i <= n;i++) c[i] = 0, adj[i].clear(); for (int i = 0;i < n - 1;i++) { int a, b; cin >> a >> b; adj[a].push_back(b); adj[b].push_back(a); } int c0 = 0, c1 = 0; vector<int> pos; for (int i = 1;i <= n;i++) { cin >> c[i]; if (c[i] == 1) c1++; else if (c[i] == 0) c0++; else pos.push_back(i); } int s = pos.size(); int ans = inf, ind = 0; if (s) { for (int i = 0;i < (1<<s);i++) { for (int j = 0;j < s;j++) { c[pos[j]] = (i & (1<<j)) ? (c1++, 1) : (c0++, 0); } dfs(1, 0); pii temp = make_pair(inf, inf); dfs2(1, 0, temp); int num = 0; if (c0) { for (int i = 1;i <= n;i++) { num = max(num, val[i].ff); //cout << val[i].ff << " " << val[i].ss << endl; } } if (c1) { for (int i = 1;i <= n;i++) num = max(num, val[i].ss); } if (num < ans) { ans = num, ind = i; } } for (int j = 0;j < s;j++) { c[pos[j]] = (ind & (1<<j)) ? 1 : 0; } } else { dfs(1, 0); pii temp = make_pair(inf, inf); dfs2(1, 0, temp); if (c0) { for (int i = 1;i <= n;i++) ans = max(ans, val[i].ff); } if (c1) { for (int i = 1;i <= n;i++) ans = max(ans, val[i].ss); } } cout << ans << endl; for (int i = 1;i <= n;i++) { //cout << val[i].ff << " " << val[i].ss << endl; cout << c[i] << " "; } cout << endl; } }
#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...