• <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 - 263, comments - 31, trackbacks - 0, articles - 3
               :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

            USACO——433——(刪除點)

            Posted on 2008-08-11 20:59 Hero 閱讀(129) 評論(0)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM
            /*
            ID: wangzha4
            LANG: C++
            TASK: race3
            */
            /*
               Test 1: TEST OK [0.000 secs, 2732 KB]
               Test 2: TEST OK [0.000 secs, 2728 KB]
               Test 3: TEST OK [0.011 secs, 2728 KB]
               Test 4: TEST OK [0.011 secs, 2728 KB]
               Test 5: TEST OK [0.011 secs, 2728 KB]
               Test 6: TEST OK [0.011 secs, 2728 KB]
               Test 7: TEST OK [0.022 secs, 2732 KB]
               Test 8: TEST OK [0.011 secs, 2728 KB]
               Test 9: TEST OK [0.011 secs, 2728 KB]
               Test 10: TEST OK [0.011 secs, 2728 KB]
               Test 11: TEST OK [0.011 secs, 2728 KB]
            */

            //ques1 :-- 直接枚舉點,刪除,然后判斷能否從起點到終點
            //ques2 :-- 從ques1中的結果集out1[]中枚舉點,從起點到該點遍歷一遍,
            //          然后從該點到終點遍歷一遍,看是否有重復遍歷的點

            #include 
            <stdio.h>
            #include 
            <stdlib.h>
            #include 
            <string.h>
            #include 
            <ctype.h>
            #include 
            <math.h>
            #define llong unsigned long long 
            #define unint unsigned int
            #define printline  printf( "\n" ) 
            typedef 
            long long huge ;

            const int Base=1000000000;
            const int Capacity=100;
            const int INF = 1000000 ;
            const int size = 60 ;

            int edge[size][size] = {0} ;

            int inn ;//the max node
            int out1[size] = {0} ; 
            int out2[size] = {0} ;
            int flag[size] = {0} ;
            int flag2[size] = {0} ;

            bool hasfind ;

            void input()
            {
                
            int inval ;
                
            for( inn=0; ; inn++ ) 
                {
                    scanf( 
            "%d"&inval ) ;    if-1 == inval ) break ;
                    
            if-2 == inval )    continue ;
                    edge[inn][inval] 
            = 1 ;
                    
            while( scanf( "%d",&inval ) != EOF && inval != -2 ) 
                        edge[inn][inval] 
            = 1 ;
                }
                inn 
            -- ;
                
            //printf( "inn==%d\n", inn ) ;
            }

            void DFS1( int sn, int en )
            {
                
            if( sn == en ) { hasfind = true ; return ; }

                flag[sn] 
            = 1 ;

                
            forint i=0; i<=inn; i++ )
                {
                    
            if0==flag[i] && edge[sn][i] )
                    {
                        DFS1( i, en ) ;
                    }
                }
            }

            void deal_ques1()
            {
                
            int copyedgein[size] ; int copyedgeout[size] ;
                
            forint i=1; i<inn; i++ ) 
                {
            //刪除一個node,看能否從起點到達終點

                    memset( flag, 
            0sizeof(flag) ) ;

                    
            forint j=0; j<=inn; j++ )
                    {
                        copyedgein[j] 
            = edge[i][j] ;
                        edge[i][j] 
            = 0 ;
                    }
                    
            forint j=0; j<=inn; j++ ) 
                    {
                        copyedgeout[j] 
            = edge[j][i] ;
                        edge[j][i] 
            = 0 ;
                    }

                    hasfind 
            = false ;
                    DFS1( 
            0, inn ) ;
                    
            if!hasfind ) out1[++out1[0]] = i ;

                    
            forint j=0; j<=inn; j++ )    edge[i][j] = copyedgein[j] ;
                    
            forint j=0; j<=inn; j++ ) edge[j][i] = copyedgeout[j] ;
                }
            }

            void DFS2( int sn, int en )
            {
                flag2[sn] 
            = 1 ;
                
            forint i=0; i<=inn; i++ )
                    
            if( edge[sn][i] && 0==flag2[i] ) DFS2( i, en ) ;
            }

            void deal_ques2()
            {
                
            forint i=1; i<=out1[0]; i++ )
                {
                    memset( flag, 
            0sizeof(flag) ) ;
                    memset( flag2, 
            0sizeof(flag2) ) ;
                    
            int delnode = out1[i] ;

                    DFS2( delnode, inn ) ;
                    DFS1( 
            0, delnode ) ;

                    
            bool iskey = true ;
                    
            forint k=0; k<=inn; k++ )
                    {
                        
            if( flag[k]==1 && flag2[k]==1 )
                        { iskey 
            = false ; break ; }
                    }
                    
            if( iskey ) out2[++out2[0]] = delnode ;
                }
            }

            void process()
            {
                deal_ques1() ;

                deal_ques2() ;
            }

            int cmp( const void *a, const void *b )
            {
                
            return *(int *)a - *(int *)b ;
            }

            void output()
            {
                qsort( out1
            +1, out1[0], sizeof(out1[1]), cmp ) ;

                printf( 
            "%d", out1[0] ) ;
                
            forint i=1; i<=out1[0]; i++ )
                    printf( 
            " %d", out1[i] ) ;
                printf( 
            "\n" ) ;

                qsort( out2
            +1, out2[0], sizeof(out2[1]), cmp ) ;
                printf( 
            "%d", out2[0] ) ;
                
            forint i=1; i<=out2[0]; i++ )
                    printf( 
            " %d", out2[i] ) ;
                printf( 
            "\n" ) ;
            }

            int main()
            {
                
            //freopen( "race3.in", "r", stdin ) ;
                
            //freopen( "race3.out","w",stdout ) ;

                input() ;

                process() ;

                output() ;

                
            return 0 ;
            }
            欧美麻豆久久久久久中文| 久久香综合精品久久伊人| 久久久精品人妻一区二区三区蜜桃| 成人免费网站久久久| 国产精品99久久久久久www| 成人久久精品一区二区三区 | 潮喷大喷水系列无码久久精品| 欧美久久综合九色综合| 亚洲欧美精品伊人久久| 青草影院天堂男人久久| 亚洲国产天堂久久综合| 久久人人爽人人爽人人片av高请| 国产成人久久AV免费| 亚洲国产成人久久综合碰| 久久99热狠狠色精品一区| 国产色综合久久无码有码| 久久国产成人午夜aⅴ影院| 久久亚洲AV成人无码电影| 色老头网站久久网| 国产精品成人无码久久久久久| 狠狠综合久久综合88亚洲 | 久久精品免费观看| 亚洲午夜久久久久妓女影院| 欧美午夜精品久久久久久浪潮| 国产V亚洲V天堂无码久久久| 久久综合色之久久综合| 久久久不卡国产精品一区二区| 久久不射电影网| 亚洲天堂久久精品| 91精品国产综合久久久久久 | 久久久久亚洲AV综合波多野结衣| 色综合久久综精品| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久久噜噜噜久久中文字幕色伊伊| 91久久精品国产91性色也| 久久精品男人影院| 伊人久久大香线蕉无码麻豆| 91久久香蕉国产熟女线看| 国产精品综合久久第一页| 99久久国产免费福利| 久久亚洲美女精品国产精品|