Pagini recente » Cod sursa (job #2816993) | Cod sursa (job #1737573) | Cod sursa (job #1623916) | Cod sursa (job #82204) | Cod sursa (job #3326792)
// Source: https://usaco.guide/general/io
#include <bits/stdc++.h>
using namespace std;
long long n,val[16005],x,y,dp[16005],vis[16005];
vector <int> v[16005];
void dfs(int node)
{
vis[node]=1;
for(int i=0;i<v[node].size();i++)
{
int vecin=v[node][i];
if(vis[vecin]==0)
{
dfs(vecin);
if(dp[vecin]>0)
{
dp[node]+=dp[vecin];
}
}
}
}
int main() {
ifstream cin("asmax.in");
ofstream cout("asmax.out");
cin>>n;
for(int i=1;i<=n;i++)
cin>>val[i];
for(int i=1;i<n;i++)
{
cin>>x>>y;
v[x].push_back(y);
v[y].push_back(x);
}
for(int i=1;i<=n;i++)
dp[i]=val[i];
dfs(1);
long long maxi=-1e26;
for(int i=1;i<=n;i++)
maxi=max(maxi,dp[i]);
cout<<maxi;
}