• <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 閱讀(120) 評論(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 ;
            }
            91麻精品国产91久久久久| 久久久久人妻一区精品性色av| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久人人爽人人爽人人片av高请| 性高湖久久久久久久久| 日韩精品久久久久久| 无码人妻少妇久久中文字幕| 人妻久久久一区二区三区| 欧美日韩精品久久久久| 99精品国产在热久久| 国产成人综合久久久久久| 成人综合久久精品色婷婷| 久久久精品午夜免费不卡| 精品久久久久成人码免费动漫| 色综合久久中文综合网| 久久久精品人妻一区二区三区蜜桃| 久久99国产精品一区二区| 综合久久国产九一剧情麻豆| 久久久无码精品午夜| 国产成人无码精品久久久免费 | 国产精品成人久久久| 精品无码久久久久久久久久| 久久婷婷国产综合精品| 久久无码AV中文出轨人妻| 久久综合精品国产一区二区三区| 99久久亚洲综合精品成人| 成人免费网站久久久| 99久久免费国产特黄| 亚洲AV无码成人网站久久精品大| 亚洲日本va午夜中文字幕久久| 久久99精品国产99久久6| 久久成人国产精品一区二区| 久久久久久毛片免费看| yellow中文字幕久久网| 精品久久久久久国产三级| 伊人热人久久中文字幕| 精品久久人人做人人爽综合| 精品国产乱码久久久久久浪潮| 国产亚洲色婷婷久久99精品91| 国产精品久久久天天影视香蕉 | 国内精品久久久久久久久电影网|