Cod sursa(job #1472437)

Utilizator BlaugranasEnal Gemaledin Blaugranas Data 17 august 2015 06:46:32
Problema Diametrul unui arbore Scor 100
Compilator c Status done
Runda Arhiva educationala Marime 0.71 kb
#include<stdio.h>
#include<stdlib.h>
int i,n,c[100001],v[100001],l,d,a[100000],b[100000],w[100001],*g[100001],o[500000],e[100001],p,u;
void B(int t) {
    for(int i=1;i<=n;i++)
    	c[i]=v[i]=0;
    for(o[u++]=t,c[t]=v[t]=1;p<u;p++)
    for(int k=o[p],i=0;i<w[k];i++)
    if(!v[g[k][i]])
        o[u++]=g[k][i],c[g[k][i]]=c[k]+1,v[g[k][i]]=1,d=c[g[k][i]],l=g[k][i];
}
int main() {
	freopen("darb.in","r",stdin),freopen("darb.out","w",stdout),scanf("%d",&n);
    for(i=0;i<n-1;i++)
    	scanf("%d%d",&a[i],&b[i]),w[a[i]]++,w[b[i]]++;
    for(i=1;i<=n;w[i++]=0)
    	g[i]=(int*)malloc(w[i]*sizeof(int));
    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);
}