Pagini recente » Cod sursa (job #566835) | Cod sursa (job #1128425) | Cod sursa (job #2756271) | Cod sursa (job #1270522) | Cod sursa (job #506984)
Cod sursa(job #506984)
#include<stdio.h>
#define dim 100005
using namespace std;
int tati[dim],v[dim],n,x,y,t,i,N,nr;
void stramosi(int k)
{
k--;
t=tati[t];
if(k==0)
return;
else stramosi(k);
}
int main()
{
FILE *f=fopen("cerere.in","r"), *g=fopen("cerere.out","w");
fscanf(f,"%d",&n);
for(i=1;i<=n;i++)
fscanf(f,"%d",&v[i]);
for(i=1;i<n;i++)
{
fscanf(f,"%d %d",&x,&y);
tati[y]=x;
}
for(i=1;i<=n;i++)
{
nr=v[i];
if(nr==0)
fprintf(g,"0 ");
else
{ N=0; t=i;
while(nr!=0)
{ N++;
stramosi(nr);
nr=v[t];
}
fprintf(g,"%d ",N);
}
}
fprintf(g,"\n");
fclose(f);
fclose(g);
return 0;
}