Submission #502224

#TimeUsernameProblemLanguageResultExecution timeMemory
502224amunduzbaevPower Plant (JOI20_power)C++14
0 / 100
1 ms332 KiB
#include "bits/stdc++.h" using namespace std; #define ar array //~ #define int long long const int N = 2e3 + 5; vector<int> edges[N]; int a[N], dp[N]; void dfs(int u, int p = -1){ int cnt = 0; for(auto x : edges[u]){ if(x == p) continue; dfs(x, u); dp[u] += dp[x]; cnt += (dp[x] > 0); } if(cnt > 1) dp[u] = max(dp[u] - a[u], 0); if(a[u]) dp[u] = max(dp[u], 1); } signed main(){ ios::sync_with_stdio(0); cin.tie(0); int n; cin>>n; for(int i=1;i<n;i++){ int a, b; cin>>a>>b; edges[a].push_back(b); edges[b].push_back(a); } for(int i=1;i<=n;i++){ char c; cin>>c; a[i] = c - '0'; } int res = 0; for(int i=1;i<=n;i++){ memset(dp, 0, sizeof dp); dfs(i); //~ cout<<dp[i]<<"\n"; res = max(res, dp[i]); } cout<<res<<"\n"; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...