• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 25,  comments - 0,  trackbacks - 0


            Genealogical tree. 家譜樹 Time Limit: 1 second Memory Limit: 16M


            Background 大意:火星人的種族關系比較混亂。宗族管理委員會進行開會發言等活動時,又想遵守先長輩,后晚輩的順序。 于是有下面的問題:

            Problem 編寫一個程序對給定的人員,決定一個先后順序, 這個順序必須遵守先長輩,后晚輩的原則。

            Input 首行為N, 1 <= N <= 100 ,N為總人數。根據百年傳統,給人員用自然數編號為1至N。以下的N行,第I行為第I個人的子孫列表,子孫的順序是任意的,用空格隔開,且以0為結束。子孫列表可以是空的。

            Output 在一行內輸出發言的順序。 如有多個順序滿足條件,則輸出任一個。至少會有一個滿足的順序的。

            Sample Input

            5 0 4 5 1 0 1 0 5 3 0 3 0

            Sample Output

            2 4 5 3 1
            /* URAL 1022 Genealogical tree
             * 900803 09:04:18 21 Aug 2005 RoBa 1022 C++ Accepted 0.001 190 KB 
             * 拓撲排序 
             
            */
             
            #include 
            <stdio.h>
            #include 
            <stdlib.h>
            #include 
            <string.h>

            const int MAX = 101;
            int map[MAX][MAX],inde[MAX],taken[MAX];

            int main()
            {
                
            int i,n,tmp,j;
                
            while (scanf("%d",&n)!=EOF)
                {
                    memset(map,
            0,sizeof(map));
                    memset(inde,
            0,sizeof(inde));
                    
            for (i = 1 ; i <= n ; i++)
                        
            while (scanf("%d",&tmp),tmp)
                        {
                            map[i][tmp] 
            = 1;
                            
            ++inde[tmp];
                        }
                    
            while (1)
                    {
                        
            for (i = 1 ; i <= n ; i++)
                            
            if (inde[i] == 0 && taken[i] == 0break;
                        
            if (i > n) break;
                        
            for (j = 1 ; j <= n ; j++)
                            
            if (map[i][j])
                            {
                                map[i][j] 
            = 0;
                                
            --inde[j];
                            }
                        taken[i] 
            = 1;
                        printf(
            "%d ",i);   
                    }
                    printf(
            "\n");
                }
                
            return 0;
            }               
            posted on 2011-10-06 19:19 nk_ysg 閱讀(316) 評論(0)  編輯 收藏 引用 所屬分類: 算法
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            午夜不卡久久精品无码免费| 欧美久久综合九色综合| 久久天天躁狠狠躁夜夜躁2014| 日韩十八禁一区二区久久| 77777亚洲午夜久久多人| 中文精品久久久久国产网址| 久久乐国产综合亚洲精品| 99久久伊人精品综合观看| 日韩av无码久久精品免费| 久久天天躁狠狠躁夜夜不卡| 精品永久久福利一区二区| 思思久久好好热精品国产 | 久久精品黄AA片一区二区三区| 久久久久久久综合日本| 9999国产精品欧美久久久久久| 久久久久99这里有精品10| 久久er国产精品免费观看2| 久久精品国产亚洲av麻豆色欲| 久久国产一片免费观看| 91视频国产91久久久| 久久久久亚洲精品无码蜜桃| 久久嫩草影院免费看夜色| 69久久夜色精品国产69| 亚洲va久久久噜噜噜久久狠狠| 久久毛片免费看一区二区三区| 久久91亚洲人成电影网站| 欧洲人妻丰满av无码久久不卡| 久久九九久精品国产免费直播| 精品久久久久久国产牛牛app| 久久精品免费网站网| 亚洲国产成人久久精品影视 | 亚洲国产精品人久久| 国内精品久久久久影院优 | 久久SE精品一区二区| 久久综合久久鬼色| 欧美久久一级内射wwwwww.| 久久久精品波多野结衣| 久久天天日天天操综合伊人av| 久久精品亚洲精品国产欧美| 久久久久99精品成人片三人毛片| 久久精品免费观看|