Cerința
Înainte de a participa la Olimpiada Naționala de Informatică, Zoli s-a decis să se plimbe prin oraș. Orașul în care locuiește Zoli are forma unui arbore, fiecare nod reprezentând o locuință iar deplasarea între acestea se efectuează prin intermediul muchiilor.
Zoli dorește să determine lungimea maximă dintre oricare două locuințe din orașul său.
Date de intrare
Fișierul de intrare ascensiune.in
conține pe prima linie numărul n
, numărul de locuințe, iar pe următoarele n-1
linii câte două numere naturale a
, b
separate prin spații, reprezentând posibilitatea de deplasare bidirecțională între două locuințe.
Date de ieșire
Fișierul de ieșire ascensiune.out
va conține pe prima linie un număr natural, reprezentând lungimea dintre cele mai îndepărtate locuințe din oraș.
Restricții și precizări
1 ≤ n ≤ 100000
- Pentru 40% dintre teste,
1 ≤ n ≤ 1000
- Distanța dintre două locuințe reprezintă numărul minim de locuințe intermediare prin care se poate ajunge de la una la cealaltă, inclusiv locuințele inițiale.
Exemplu
ascensiune.in
8 1 2 1 3 2 4 2 5 3 6 3 7 5 8
ascensiune.out
6
Explicație
Cele mai îndepărtate două locuințe sunt cele cu numărul de ordine 8, respectiv 6 sau 7. Distanța dintre acestea este de 6 locuințe.
#include <bits/stdc++.h> using namespace std; ifstream cin("ascensiune.in"); ofstream cout("ascensiune.out"); int n , m , P[100002] , d[100002] , x , y , maxi , maxi1 , ind; vector <int> G[100002]; void bfs(int v) { queue <int> Q; Q.push(v); P[v] = 1; d[v] = 1; while(!Q.empty()) { int x = Q.front(); Q.pop(); for(auto p:G[x]) if(!P[p]) Q.push(p) , P[p] = 1 , d[p] = d[x] + 1; } } int main() { cin >> n; while(cin >> x >> y) { G[x].push_back(y); G[y].push_back(x); m++; } bfs(1); for(int i = 1 ; i <= n ; i++) if(d[i] > maxi) maxi = d[i] , ind = i; for(int i = 1 ; i <= n ; i++) d[i] = 0 , P[i] = 0; bfs(ind); for(int i = 1 ; i <= n ; i++) if(d[i] > maxi1) maxi1 = d[i]; cout << maxi1; }