Pagini recente » Cod sursa (job #91778) | Cod sursa (job #215635) | Cod sursa (job #2810758) | Cod sursa (job #14515) | Cod sursa (job #2898720)
#include<bits/stdc++.h>
using namespace std;
ifstream f("asmax.in");
ofstream g("asmax.out");
#define N 16005
vector<int> t[N];
bool o[N];
int i,j,n,m=-16e6,v[N];
void D(int i)
{
int j,k;
for(o[i]=1,k=t[i].size(),j=0;j<k;++j)
if(!o[t[i][j]])
D(t[i][j]),v[i]=max(v[i],v[i]+v[t[i][j]]);
}
int main()
{
for(f>>n,i=1;i<=n;f>>v[i],++i);
for(;f>>i>>j;t[i].push_back(j),t[j].push_back(i));
for(D(1),i=1;i<=n;m=max(m,v[i]),++i);
return g<<m,0;
}