Submission #668687

#TimeUsernameProblemLanguageResultExecution timeMemory
668687stevancvPower Plant (JOI20_power)C++14
100 / 100
162 ms33112 KiB
#include <bits/stdc++.h> #define ll long long #define ld long double #define sp ' ' #define en '\n' #define smin(a, b) a = min(a, b) #define smax(a, b) a = max(a, b) using namespace std; const int N = 2e5 + 2; const int inf = 2e9; vector<int> g[N]; int dp[N][2]; int str[N]; void Dfs(int s, int e) { dp[s][0] = str[s]; dp[s][1] = -inf; int sum = 0; for (int u : g[s]) if (u != e) { Dfs(u, s); sum += dp[u][0]; smax(dp[s][1], dp[u][1] - str[s]); if (str[s] && dp[u][0]) smax(dp[s][1], dp[u][0] + 1); } smax(dp[s][0], sum - str[s]); int fs = sum; for (int u : g[s]) if (u != e) { if (str[s] || sum > dp[u][0]) fs += max(0, dp[u][1] - 2 - dp[u][0]); } smax(dp[s][0], fs - str[s]); } int main() { ios::sync_with_stdio(false); cin.tie(0); cout.tie(0); int n; cin >> n; for (int i = 0; i < n - 1; i++) { int u, v; cin >> u >> v; u -= 1; v -= 1; g[u].push_back(v); g[v].push_back(u); } string sr; cin >> sr; for (int i = 0; i < n; i++) str[i] = sr[i] - '0'; Dfs(0, -1); int ans = -inf; for (int i = 0; i < n; i++) smax(ans, max(dp[i][0], dp[i][1])); cout << ans << en; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...