Cod sursa(job #2489178)

Utilizator Bogdan_BuzatuBuzatu Bogdan Mihai Bogdan_Buzatu Data 7 noiembrie 2019 23:35:50
Problema Diametrul unui arbore Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.97 kb
#include <fstream>
#include <vector>
#include <algorithm>
using namespace std;

ifstream fin ("darb.in");
ofstream fout("darb.out");
vector<int> L[100010];
int n, x, y,tat[100010],k,c,niv[100010],maxim,start;

void dfs(int nod) {
    niv[nod]=niv[tat[nod]]+1;
    for (int i=0;i<L[nod].size(); i++) {
        int vecin = L[nod][i];
        if (vecin!=tat[nod]){
            tat[vecin]=nod;
            dfs(vecin);
        }
    }

}
int main(){
    fin>>n;
    for(int i=1;i<=n;i++){
        fin>>x>>y;
        L[x].push_back(y);
        L[y].push_back(x);
    }
    tat[1]=0;
    dfs(1);
    maxim=-1;
    for(int i=1;i<=n;i++){
        tat[i]=0;

        if(niv[i]>maxim){
            maxim=niv[i];
            start=i;
        }
        niv[i]=0;
    }

    tat[start]=0;
    maxim=-1;
    dfs(start);
    for(int i=1;i<=n;i++){
        if(niv[i]>maxim){
            maxim=niv[i];
        }
    }
    fout<<maxim;


    return 0;
}