Submission #306758

#TimeUsernameProblemLanguageResultExecution timeMemory
306758MrDominoPower Plant (JOI20_power)C++14
47 / 100
1597 ms23540 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef long double ld; const int N = (int) 2e5 + 7; int n; vector<int> g[N]; int v[N]; int dp[N]; int sol; void compute(int a, int p) { dp[a] = -v[a]; for (auto &b : g[a]) { if (b != p) { dp[a] += dp[b]; } } dp[a] = max(dp[a], v[a]); } void dfs(int a, int p) { for (auto &b : g[a]) { if (b != p) { dfs(b, a); } } compute(a, p); } void reroot(int a, int p) { compute(a, p); compute(p, -1); } void dfs_solve(int a, int p) { sol = max(sol, dp[a]); for (auto &b : g[a]) { if (b != p) { reroot(a, b); dfs_solve(b, a); reroot(b, a); } } } int main() { ios::sync_with_stdio(0); cin.tie(0); cin >> n; for (int i = 1; i < n; i++) { int x, y; cin >> x >> y; g[x].push_back(y); g[y].push_back(x); } string s; cin >> s; for (int i = 1; i <= n; i++) { if (s[i - 1] == '1') { v[i] = 1; sol++; } } sol = min(sol, 2); dfs(1, -1); dfs_solve(1, -1); cout << sol << "\n"; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...