Pagini recente » Diferente pentru olimpici intre reviziile 81 si 82 | Istoria paginii runda/forta/clasament | Istoria paginii runda/ah7/clasament | Istoria paginii runda/moisil2018 | Cod sursa (job #2829832)
#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 dfs(int start)
{
visited[start] = true;
for(auto vecin:la[start])
{
if(!visited[vecin])
{
valori[start] = max( valori[start], valori[start]+dfs(vecin));
}
}
return valori[start];
}
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);
}
g<<dfs(1);
return 0;
}