Pagini recente » Cod sursa (job #1891171) | Cod sursa (job #1913073) | Cod sursa (job #569476) | Cod sursa (job #567679) | Cod sursa (job #100299)
Cod sursa(job #100299)
#include <cstdio>
#include <vector>
#include <bitset>
#include <queue>
#define maxN 100001
using namespace std;
int Tt;
int N;
int Niv[maxN];
int Nmax[maxN];
int T[maxN];
struct elem
{
int nod;
int nv;
};
class comp
{
public:
bool operator()(elem a, elem b)
{
return a.nv < b.nv;
}
};
vector <int> V[maxN];
queue <int> q;
priority_queue<elem, vector <elem>, comp> pq;
void df_niv(int nod)
{
int i;
for(i=0; i<V[nod].size(); ++i)
{
Niv[V[nod][i]] = Niv[nod] + 1;
df_niv(V[nod][i]);
if(!Nmax[V[nod][i]])
Nmax[V[nod][i]] = Niv[V[nod][i]];
Nmax[nod] = Nmax[nod] > Nmax[V[nod][i]] ? Nmax[nod] : Nmax[V[nod][i]];
}
}
void bfs()
{
q.push(1);
int nod, i, k;
elem x;
while(q.empty() == false)
{
nod = q.front();
q.pop();
for(i=0; i<V[nod].size(); ++i)
{
x.nod = V[nod][i];
x.nv = Nmax[x.nod];
pq.push(x);
}
k = 1;
while(pq.empty() == false)
{
x = pq.top();
pq.pop();
q.push(x.nod);
T[x.nod] = T[nod] + k;
++ k;
}
}
}
int main()
{
freopen("zvon.in", "rt", stdin);
freopen("zvon.out", "wt", stdout);
int i, a, b;
for(scanf("%d", &Tt); Tt; --Tt)
{
for(scanf("%d", &N), i=1; i<N; ++i)
{
scanf("%d %d", &a, &b);
V[a].push_back(b);
}
Niv[1] = 0;
df_niv(1);
T[1] = 0;
bfs();
int sol = 0;
for(i=1; i<=N; ++i)
{
sol = T[i] > sol ? T[i] : sol;
Nmax[i] = 0;
Niv[i] = 0;
T[i] = 0;
V[i].clear();
}
printf("%d\n", sol);
}
fclose(stdin);
fclose(stdout);
return 0;
}