码迷,mamicode.com
首页 > 其他好文 > 详细

家谱树

时间:2017-04-14 22:13:48      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:整数   using   个人   ack   i++   接下来   序列   return   格式   

【问题描述】
    有个人的家族很大,辈分关系很混乱,请你帮整理一下这种关系。
    给出每个人的孩子的信息。
    输出一个序列,使得每个人的后辈都比那个人后列出。
【输入格式】
    第1行一个整数N(1<=N<=100),表示家族的人数。
    接下来N行,第I行描述第I个人的儿子。
    每行最后是0表示描述完毕。
【输出格式】
    输出一个序列,使得每个人的后辈都比那个人后列出。
    如果有多解输出任意一解。
【输入样例】
    5
    0
    4 5 1 0
    1 0
    5 3 0
    3 0
【输出样例】
    2 4 5 3 1
 1 #include<iostream>
 2 #include<cstdio>
 3 using namespace std;
 4 int rd[1000];
 5 int ch[1000];
 6 int stack[1000];
 7 int a[1000][1000];
 8 int main()
 9 {
10     int n;
11     cin>>n;
12     for(int i=1;i<=n;i++)
13      {
14          int x;
15           do{
16               cin>>x;
17               if(x!=0)
18                {
19                  ch[i]++;
20                  a[i][ch[i]]=x;
21                  rd[x]++;
22              }
23               }while(x!=0);
24     }
25      int top=0,sum=0;
26      for(int i=1;i<=n;i++)
27       {
28           if(rd[i]==0)
29            {
30                stack[++top]=i;
31            }
32       }
33      do
34      {
35         int i=stack[top];
36           cout<<i<<" ";
37           top--;
38           sum++;
39         for(int j=1;j<=ch[i];j++)
40         {
41            rd[a[i][j]]--;
42            if(rd[a[i][j]]==0)
43             {
44                 stack[++top]=a[i][j];
45              }
46          }
47       }while(sum!=n);
48       return 0;
49           
50       
51 }

 

家谱树

标签:整数   using   个人   ack   i++   接下来   序列   return   格式   

原文地址:http://www.cnblogs.com/sssy/p/6711086.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!