Cod sursa(job #2990846)

Utilizator karina_antoniuAntoniu Karina karina_antoniu Data 8 martie 2023 17:16:00
Problema Asmax Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.79 kb
#include <fstream>
#include <vector>
using namespace std;

ifstream cin("asmax.in");
ofstream cout("asmax.out");

const int N = 16000;
vector <int> a[N + 1];
int scor[N + 1], vizitat[N + 1], n, val[N + 1], maxim = -1e9;

void dfs(int x)
{
    vizitat[x] = 1;
    scor[x] = val[x];
    for(auto i : a[x])
        if(!vizitat[i])
        {
            dfs(i);
            if(scor[i] > 0)
                scor[x] += scor[i];
        }
}

int main()
{
    cin >> n;
    for(int i = 1; i <= n; i++)
        cin >> val[i];
    int x, y;
    while(cin >> x >> y)
    {
        a[x].push_back(y);
        a[y].push_back(x);
    }
    dfs(1);
    for(int i = 1; i <= n; i++)
        if(scor[i] > maxim)
            maxim = scor[i];
    cout << maxim << "\n";
    return 0;
}