Pagini recente » Cod sursa (job #2058825) | Cod sursa (job #2561130) | Cod sursa (job #1768641) | Cod sursa (job #1375749) | Cod sursa (job #2679380)
#include <bits/stdc++.h>
using namespace std;
ifstream f("asmax.in");
ofstream g("asmax.out");
vector <int> a[16001];
int n,val[16001],summax=INT_MIN;
int dfs(int x=1, int node=-1)
{
int y;
for(int k:a[x])
if(k!=node)
{
y=dfs(k,x);
if(y>0) val[x]+=y;
}
return val[x];
}
int main()
{
f>>n;
for(int k=1;k<=n;k++) f>>val[k];
for(int k=1;k<n;k++)
{
int i,j;
f>>i>>j;
a[i].push_back(j);
a[j].push_back(i);
}
dfs();
for(int i=1;i<=n;i++)
summax=max(summax,val[i]);
g<<summax;
}