• <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 413--(floyed最小環(huán))

            Posted on 2008-07-30 12:23 Hero 閱讀(305) 評論(0)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM

            /*
            ID: wangzha4
            LANG: C++
            TASK: fence6
            */

            //利用floyed算法求最小環(huán)--參見圖片的算法

            /*
            Executing
               Test 1: TEST OK [0.000 secs, 2848 KB]
               Test 2: TEST OK [0.011 secs, 2852 KB]
               Test 3: TEST OK [0.000 secs, 2848 KB]
               Test 4: TEST OK [0.000 secs, 2848 KB]
               Test 5: TEST OK [0.011 secs, 2848 KB]
               Test 6: TEST OK [0.000 secs, 2848 KB]
               Test 7: TEST OK [0.000 secs, 2852 KB]
               Test 8: TEST OK [0.011 secs, 2852 KB]
               Test 9: TEST OK [0.000 secs, 2848 KB]
            */
            #include 
            <stdio.h>
            #include 
            <stdlib.h>
            #include 
            <string.h>
            #include 
            <ctype.h>
            #define llong unsigned long long 
            #define unint unsigned int
            #define printline  printf( "\n" ) 

            double fmax( double a, double b )
            {
                
            if( a - b > 0 )    return a ;
                
            else            return b ;
            }

            double fmin( double a, double b )
            {
                
            if( a - b < 0 )    return a ;
                
            else            return b ;
            }

            int fmax( int a, int b )
            {
                
            if( a > b )    return a ;
                
            else        return b ;
            }

            int fmin( int a, int b )
            {
                
            if( a < b )    return a ;
                
            else        return b ;
            }

            int fpow( int a, int b )
            {
                
            int reval = 1 ;
                
            forint i=1; i<=b; i++ )
                    reval 
            *= a ;
                
            return reval ;
            }
            const int INF = 1000000 ;
            const int size = 120 ;

            int inn ; int out = INF ;
            int edge[size][size] ;
            int dist[size][size] ;
            int flen[size] ;
            int left[size][10] ;
            int right[size][10] ;
            bool inleft[size][size] = { false } ;
            int flag[size] = {0} ;

            int minCircle()
            {
            //尋找最小環(huán)
                forint i=0; i<=inn; i++ ) forint j=0; j<=inn; j++ )
                    dist[i][j] 
            = edge[i][j] ;//dist數(shù)組初始化

                
            int reval = INF ;
                
            forint k=1; k<=inn; k++ )
                {
            //枚舉最大的點
                    forint i=1; i<=left[k][0]; i++ ){//從最大點的左邊選出小于當前最大點的左節(jié)點
                        int curleft = left[k][i] ;
                        
            if( curleft < k ){
                            
            forint j=1; j<=right[k][0]; j++ ){//從最大點的右邊選出小于當前最大點的右節(jié)點
                                int curright = right[k][j] ;
                                
            if( curright < k ){
                                    reval 
            = fmin( reval, dist[curleft][curright]+edge[curleft][k]+edge[k][curright] ) ;
                                }
            //構成環(huán)
                            }
                        }
                    }

                    
            forint i=1; i<=inn; i++ ) forint j=1; j<=inn; j++ )
                        
            if( i==|| i==|| j==k )    continue ;
                        
            else    dist[i][j] = dist[j][i] = fmin( dist[i][j], dist[i][k]+dist[k][j] ) ;
                }

                
            return reval ;
            }

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

                scanf( 
            "%d",&inn ) ; int fnum ;
                
            forint i=1; i<=inn; i++ )
                {
                    scanf( 
            "%d",&fnum ) ;
                    scanf( 
            "%d",&flen[fnum] ) ;
                    scanf( 
            "%d %d",&left[fnum][0],&right[fnum][0] ) ;

                    
            forint j=1; j<=left[fnum][0]; j++ ){
                        scanf( 
            "%d",&left[fnum][j] ) ;
                        inleft[fnum][left[fnum][j]] 
            = true ;
                    }
                    
            forint j=1; j<=right[fnum][0]; j++ ){
                        scanf( 
            "%d",&right[fnum][j] ) ;
                    }
                }
            //data input

                
            forint i=0; i<=inn; i++ ){
                    
            forint j=0; j<=inn; j++ ){
                        edge[i][j] 
            = dist[i][j] = INF ;
                    }
                }
            //edge init

                
            forint i=1; i<=inn; i++ )
                {
                    
            forint j=1; j<=left[i][0]; j++ )
                        edge[i][left[i][j]] 
            = flen[i] + flen[left[i][j]] ;
                    
            forint j=1; j<=right[i][0]; j++ )
                        edge[i][right[i][j]] 
            = flen[i] + flen[right[i][j]] ;
                }

                
            out = minCircle() ;

                printf( 
            "%d\n",out/2 ) ;

                
            return 0 ;
            }
            精品一久久香蕉国产线看播放| 久久中文字幕人妻丝袜| 韩国免费A级毛片久久| 国产成人久久AV免费| 97精品国产97久久久久久免费| 久久久久黑人强伦姧人妻 | 精品久久久久久无码中文字幕一区| 人妻少妇久久中文字幕 | 久久99国产综合精品| 欧美综合天天夜夜久久| 2021最新久久久视精品爱| 亚洲精品国产美女久久久| 国产精品免费久久久久久久久| 久久综合亚洲鲁鲁五月天| 99久久精品无码一区二区毛片| 一级A毛片免费观看久久精品| 无码国内精品久久人妻蜜桃| 88久久精品无码一区二区毛片 | www.久久热.com| 久久婷婷午色综合夜啪| 久久精品国产亚洲麻豆| 亚洲综合精品香蕉久久网| 久久久久亚洲av成人无码电影| 成人综合伊人五月婷久久| 亚洲国产成人精品无码久久久久久综合 | 香蕉久久永久视频| 久久国产精品国语对白| 成人资源影音先锋久久资源网| 7777久久久国产精品消防器材| 久久久久国产成人精品亚洲午夜| 久久国产热精品波多野结衣AV| 精品综合久久久久久98| 中文字幕无码久久久| 日本久久久久久久久久| 久久午夜福利电影| 久久久久国产| 日本亚洲色大成网站WWW久久| 久久免费99精品国产自在现线 | 内射无码专区久久亚洲| 亚洲欧美另类日本久久国产真实乱对白| 曰曰摸天天摸人人看久久久|