Pagini recente » Cod sursa (job #2296825) | Cod sursa (job #551739) | Cod sursa (job #1928277) | Cod sursa (job #27310) | Cod sursa (job #3232561)
#include <vector>
#include <algorithm>
#include <fstream>
#include <limits>
using namespace std;
const int nmax = 16010;
ifstream in("asmax.in");
ofstream out("asmax.out");
int n, v[nmax], mx[nmax];
vector<int> g[nmax];
bool used[nmax];
void dfs(int node) {
if (used[node]) {
return;
}
used[node] = 1;
mx[node] = v[node];
for (int vec : g[node]) {
if (!used[vec]) {
dfs(vec);
mx[node] += max(mx[vec], 0);
}
}
}
int main() {
in >> n;
for (int i = 1; i <= n; i++) {
in >> v[i];
}
for (int i = 1; i < n; i++) {
int a, b;
in >> a >> b;
g[a].push_back(b);
g[b].push_back(a);
}
dfs(1);
int res = numeric_limits<int>::min();
for (int i = 1; i <= n; i++) {
res = max(res, mx[i]);
}
out << res << "\n";
return 0;
}