• <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>
            #include <stdio.h>
            #include 
            <stdlib.h>
            #include 
            <math.h>
            #include 
            <string.h>

            #define INF 99999999
            #define min( a, b ) ( (a)< (b)?(a): (b) )

            int  x[110], y[110], father[110];
            double map[110][110], ans;
            bool   visite[110], circle[110];
            int    n, m, root;

            void dfs( int t )
            {
                visite[t]
            = true;
                
                
            forint i= 1; i<= n; ++i )
                
            if!visite[i] && map[t][i]!= INF )
                dfs( i );
            }

            bool isok()
            {
                memset( visite, 
            falsesizeof(visite) );
                dfs( root );
                
                
            forint i= 1; i<= n; ++i )
                
            if!visite[i] ) return false;
                
                
            return true;
            }

            double dist( int i, int j )
            {
                
            return sqrt( (x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]) );
            }

            int exist_circle()
            {
                root
            = 1; father[root]= root;
                
                
            forint i= 1; i<= n; ++i )
                
            if!circle[i] && i!= root )
                {
                    father[i]
            = i; map[i][i]= INF;
                    
                    
            forint j= 1; j<= n; ++j )
                    
            if!circle[j] && map[j][i]< map[father[i]][i] )
                    father[i]
            = j;
                }
                
                
            int i;
                
            for( i= 1; i<= n; ++i )
                {
                    
            if( circle[i] ) continue;
                    
                    memset( visite, 
            falsesizeof(visite) );
                    
            int j= i;
                    
            while!visite[j] ) {  visite[j]= true;  j= father[j];  }
                    
            if( j== root ) continue;
                    
                    
            return j;
                }
                
                
            return -1;
            }


            void  update( int t )
            {
                ans
            += map[father[t]][t];
                
            forint i= father[t]; i!= t; i= father[i] )
                {
                    ans
            += map[father[i]][i];
                    circle[i]
            = true;
                }
                
                
            forint i= 1; i<= n; ++i )
                
            if!circle[i] && map[i][t]!= INF )
                map[i][t]
            -= map[father[t]][t];
                
                
            forint j= father[t]; j!= t; j= father[j] )
                    
            forint i= 1; i<= n; ++i )
                    {
                        
            if( circle[i] ) continue;
                        
                        
            if( map[i][j]!= INF )
                        map[i][t]
            = min( map[i][t], map[i][j]- map[father[j]][j] );
                        
                        map[t][i]
            = min( map[j][i], map[t][i] );
                    }
            }

            void solve()
            {
                memset( circle, 
            falsesizeof(circle) );
                
                
            int j;
                
            while( ( j= exist_circle() )!= -1 ) update( j );
                
                
            for( j= 1; j<= n; ++j )
                
            if( j!= root && !circle[j] )
                ans
            += map[father[j]][j];
                
                printf(
            "%.2lf\n", ans );
            }

            int main()
            {
                
            while( scanf("%d%d",&n,&m)!= EOF )
                {
                    
            forint i= 0; i<= n; ++i )
                    
            forint j= 0; j<= n; ++j )
                    map[i][j]
            = INF;
                    
                    
            forint i= 1; i<= n; ++i )
                    scanf(
            "%d%d",&x[i], &y[i] );
                    
                    
            forint i= 0; i< m; ++i )
                    {
                        
            int a, b;
                        scanf(
            "%d%d",&a,&b);
                        
                        map[a][b]
            = dist( a, b );
                    }
                    
                    root
            = 1;  ans= 0;
                    
            if!isok() ) puts("poor snoopy");
                    
            else  solve();
                }
                
                
            return 0;
            }
            posted on 2009-02-19 22:01 Darren 閱讀(203) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            久久丫精品国产亚洲av| 青青青国产成人久久111网站| 久久久久久无码国产精品中文字幕| 久久福利青草精品资源站| 青青青国产精品国产精品久久久久| 久久九九亚洲精品| 久久精品国产色蜜蜜麻豆| 成人妇女免费播放久久久| 久久久久国产| 国内精品久久久久影院免费| 亚洲人成无码www久久久| 99久久免费国产特黄| 亚洲国产精品嫩草影院久久| 青青青国产精品国产精品久久久久| 欧美久久久久久| 国内精品久久久久久麻豆| 久久夜色精品国产噜噜亚洲AV| 日韩影院久久| 99久久国产综合精品五月天喷水| 无码人妻久久一区二区三区| 少妇被又大又粗又爽毛片久久黑人| 丁香五月网久久综合| 欧美va久久久噜噜噜久久| 国内高清久久久久久| 伊人久久精品影院| 欧美国产精品久久高清| 97精品伊人久久久大香线蕉| 99久久免费国产精品热| AV狠狠色丁香婷婷综合久久| 色欲综合久久中文字幕网| 99蜜桃臀久久久欧美精品网站| 午夜视频久久久久一区| 久久亚洲2019中文字幕| 久久婷婷人人澡人人| 久久亚洲国产成人影院网站 | 久久久久亚洲国产| 蜜臀久久99精品久久久久久| 亚洲人成无码网站久久99热国产| 青青久久精品国产免费看| 久久人人爽人人爽人人片AV东京热 | 久久国产精品久久|