Cod sursa(job #1200155)

Utilizator breahnadavidBreahna David breahnadavid Data 21 iunie 2014 23:51:24
Problema Asmax Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.79 kb
#include<iostream>
#include<vector>
#include<fstream>
#define maxn 100005

using namespace std;

ifstream f("dfs.in");
ofstream g("dfs.out");

vector <int> t[maxn];
int i,j,n,m,nod[maxn],valori[maxn],cost;

int max(int a,int b)
        {
        if(a>b)return a;
        else return b;
        }
int dfs(int k)
        {
        nod[k]=1;
        int cost=valori[k];
        for(int j=0;j<t[k].size();j++)
        if(nod[t[k][j]]==0)cost=max(max(dfs(t[k][j]),valori[t[k][j]])+cost,cost);
        return cost;
        }

int main()
{
f>>n;
for(i=1;i<=n;i++)f>>valori[i];

while(f>>i>>j)
        {
        t[i].push_back(j);
        t[j].push_back(i);
        }
cost=-1001;
int l;
for(i=1;i<=n;i++)if(nod[i]==0){l=dfs(i);if(l>cost)cost=l;}
g<<cost;
g.close();
return 0;
}