Pagini recente » Istoria paginii runda/x-treme_april_challenge | Cod sursa (job #3131714) | Cod sursa (job #704744) | Diferente pentru arhiva intre reviziile 11 si 10 | Cod sursa (job #2829838)
#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
#define Nmax 16001
ifstream f("asmax.in");
ofstream g("asmax.out");
vector<int> la[Nmax];
bool visited[Nmax];
int valori[Nmax];
int maxim =-1000;
int dfs(int start)
{
int cost = valori[start];
visited[start] = true;
for(auto vecin:la[start])
{
if(!visited[vecin])
{
cost = max(cost, cost+dfs(vecin));
}
}
maxim = max(maxim,cost);
return cost;
}
int main()
{
int n,x,y;
f>>n;
for(int i=1;i<=n;i++)
{
f>>valori[i];
}
for(int i=1;i<=n;i++)
{
f>>x>>y;
la[x].push_back(y);
la[y].push_back(x);
}
dfs(1);
g<<maxim;
return 0;
}