Cod sursa(job #2421282)

Utilizator BlaugranasEnal Gemaledin Blaugranas Data 14 mai 2019 17:25:05
Problema Diametrul unui arbore Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.76 kb
#include<cstdio>
const int N=100001,M=20000000;
int i,n,c[N],l,d,a[N],b[N],w[N],*g[N],o[5*N],p,u,e;
char r[M];
inline int A()
{
  	int s=0;
  	for(;r[e]<48;e++);
  	for(;r[e]>47;e++)
  		s=s*10+r[e]-48;
  	return s;
}
inline void B(int t)
{
	int i,k;
    for(i=1;i<=n;i++)
        c[i]=0;
    for(o[u++]=t,c[t]=1;p<u;p++)
    	for(k=o[p],i=0;i<w[k];i++)
    		if(!c[g[k][i]])
        		l=g[k][i],o[u++]=l,c[l]=c[k]+1,d=c[l];
}
int main()
{
    freopen("darb.in","r",stdin),freopen("darb.out","w",stdout),fread(r,1,M,stdin),n=A();
    for(i=0;i<n-1;i++)
        a[i]=A(),b[i]=A(),w[a[i]]++,w[b[i]]++;
    for(i=1;i<=n;w[i++]=0)
        g[i]=new int[w[i]];
    for(i=0;i<n-1;i++)
        g[a[i]][w[a[i]]++]=b[i],g[b[i]][w[b[i]]++]=a[i];
    B(1),B(l),printf("%d",d);
}