青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

POJ 3164 Command Network 最小樹形圖

Description

After a long lasting war on words, a war on arms finally breaks out between littleken’s and KnuthOcean’s kingdoms. A sudden and violent assault by KnuthOcean’s force has rendered a total failure of littleken’s command network. A provisional network must be built immediately. littleken orders snoopy to take charge of the project.

With the situation studied to every detail, snoopy believes that the most urgent point is to enable littenken’s commands to reach every disconnected node in the destroyed network and decides on a plan to build a unidirectional communication network. The nodes are distributed on a plane. If littleken’s commands are to be able to be delivered directly from a node A to another node B, a wire will have to be built along the straight line segment connecting the two nodes. Since it’s in wartime, not between all pairs of nodes can wires be built. snoopy wants the plan to require the shortest total length of wires so that the construction can be done very soon.

Input

The input contains several test cases. Each test case starts with a line containing two integer N (N ≤ 100), the number of nodes in the destroyed network, and M (M ≤ 104), the number of pairs of nodes between which a wire can be built. The next N lines each contain an ordered pair xi and yi, giving the Cartesian coordinates of the nodes. Then follow M lines each containing two integers i and j between 1 and N (inclusive) meaning a wire can be built between node i and node j for unidirectional command delivery from the former to the latter. littleken’s headquarter is always located at node 1. Process to end of file.

Output

For each test case, output exactly one line containing the shortest total length of wires to two digits past the decimal point. In the cases that such a network does not exist, just output ‘poor snoopy’.

Sample Input

4 6
0 6
4 6
0 0
7 20
1 2
1 3
2 3
3 4
3 1
3 2
4 3
0 0
1 0
0 1
1 2
1 3
4 1
2 3

Sample Output

31.19
poor snoopy

Source


 

最小樹形圖算法(Zhu-Liu Algorithm)

1.       設最小樹形圖的總權值為cost,置cost0

2.       除源點外,為其他所有節點Vi找一條權值最小的入邊,加入集合TT就是最短邊的集合。加邊的方法:遍歷所有點到Vi的邊中權值最小的加入集合T,記pre[Vi]為該邊的起點,mincost[Vi]為該邊的權值。

3.       檢查集合T中的邊是否存在有向環,有則轉到步驟4,無則轉到步驟5。這里需要利用pre數組,枚舉檢查過的點作為搜索的起點,類似dfs的操作判斷有向環。

4.       將有向環縮成一個點。設環中有點{Vk1,Vk2,…,Vki}i個點,用Vk代替縮成的點。在壓縮后的圖中,更新所有不在環中的點VVk的距離:

map[V][Vk] = min {map[V][Vkj]-mincost[Vki]} 1<=j<=i

map[Vk][V] = min {map[Vkj][V]}           1<=j<=I

5.       cost加上T中有向邊的權值總和就是最小樹形圖的權值總和。

#include <iostream>
#include 
<cmath>

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

const int MAXN = 110;
const int INF = 0x7FFFFFFF;
int n,m,pre[MAXN];
double x[MAXN],y[MAXN];
bool circle[MAXN],visit[MAXN];
double ans,map[MAXN][MAXN];

inline 
double distance(double x1,double y1,double x2,double y2){
    
return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}

void dfs(int u){
    visit[u]
=true;
    
for(int i=2;i<=n;i++)
        
if(!visit[i] && map[u][i]!=INF)
            dfs(i);
}

bool connected(){
    memset(visit,
false,sizeof(visit));
    
int i,cnt=0;
    
for(i=1;i<=n;i++)
        
if(!visit[i])
            dfs(i),cnt
++;
    
return cnt==1 ? true : false;
}

void min_arborescence(){
    
int i,j,k;
    memset(circle,
false,sizeof(circle));
    
while(true){
        
for(i=2;i<=n;i++){
            
if(circle[i]) continue;
            pre[i]
=i;
            map[i][i]
=INF;
            
for(j=1;j<=n;j++){
                
if(circle[j]) continue;
                
if(map[j][i]<map[pre[i]][i])
                    pre[i]
=j;
            }

        }

        
for(i=2;i<=n;i++){
            
if(circle[i]) continue;
            j
=i;
            memset(visit,
false,sizeof(visit));
            
while(!visit[j] && j!=1){
                visit[j]
=true;
                j
=pre[j];
            }

            
if(j==1continue;
            i
=j;
            ans
+=map[pre[i]][i];
            
for(j=pre[i];j!=i;j=pre[j]){
                ans
+=map[pre[j]][j];
                circle[j]
=true;
            }

            
for(j=1;j<=n;j++){
                
if(circle[j]) continue;
                
if(map[j][i]!=INF)
                    map[j][i]
-=map[pre[i]][i];
            }

            
for(j=pre[i];j!=i;j=pre[j])
                
for(k=1;k<=n;k++){
                    
if(circle[k]) continue;
                    map[i][k]
=min(map[i][k],map[j][k]);
                    
if(map[k][j]!=INF)
                        map[k][i]
=min(map[k][i],map[k][j]-map[pre[j]][j]);
                }

            
break;
        }

        
if(i>n){
            
for(j=2;j<=n;j++){
                
if(circle[j]) continue;
                ans
+=map[pre[j]][j];
            }

            
break;
        }

    }

}

int main(){
    
int i,j,u,v;
    
while(scanf("%d %d",&n,&m)!=EOF){
        
for(ans=i=0;i<=n;i++for(j=0;j<=n;j++) map[i][j]=INF;
        
for(i=1;i<=n;i++) scanf("%lf %lf",&x[i],&y[i]);
        
while(m--){
            scanf(
"%d %d",&u,&v);
            map[u][v]
=distance(x[u],y[u],x[v],y[v]);
        }

        
if(!connected()) puts("poor snoopy");
        
else{
            min_arborescence();
            printf(
"%.2lf\n",ans);
        }

    }

    
return 0;
}

posted on 2009-05-26 16:03 極限定律 閱讀(693) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC

<2009年5月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導航

統計

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

友情鏈接

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲福利视频一区二区| 欧美电影电视剧在线观看| 亚洲电影自拍| 蜜臀av在线播放一区二区三区 | 亚洲精品乱码久久久久| 欧美成人高清| 国产精品99久久久久久白浆小说 | 亚洲靠逼com| 欧美日韩视频第一区| 亚洲亚洲精品三区日韩精品在线视频 | 国产精品高潮呻吟久久av黑人| 亚洲夜晚福利在线观看| 亚洲综合电影| 影音先锋亚洲电影| 亚洲精品在线三区| 国产精品一区二区你懂得 | 亚洲午夜成aⅴ人片| 亚洲欧美国产高清| 在线日韩av片| a91a精品视频在线观看| 国产一区二区三区自拍| 亚洲盗摄视频| 国产欧美日本一区视频| 欧美国产视频一区二区| 国产精品狼人久久影院观看方式| 久久久久一本一区二区青青蜜月| 嫩草影视亚洲| 欧美一区二区视频在线| 欧美黄污视频| 久久精品一区蜜桃臀影院 | 久久米奇亚洲| 亚洲欧美国产不卡| 牛人盗摄一区二区三区视频| 欧美一二三区在线观看| 欧美精品成人| 久久综合一区二区| 国产精品自在在线| 亚洲乱码国产乱码精品精天堂| 国产日韩欧美另类| 日韩视频在线观看一区二区| 国语自产在线不卡| 亚洲一区成人| 99精品视频一区二区三区| 久久久久久亚洲精品杨幂换脸 | 黄色成人精品网站| 亚洲小视频在线| 日韩视频在线播放| 久热精品视频在线| 久久国产精品久久国产精品| 国产精品xxxav免费视频| 欧美国产第一页| 在线电影一区| 久久久久免费观看| 久久免费国产| 国产亚洲精品bt天堂精选| 亚洲一区国产视频| 亚洲男人的天堂在线观看| 欧美日本亚洲韩国国产| 亚洲黄色小视频| 亚洲国产精品成人久久综合一区| 久久www免费人成看片高清 | 黄色工厂这里只有精品| 亚洲欧美一区二区激情| 亚洲免费视频成人| 欧美日韩一区在线观看| 亚洲精品自在久久| 一区二区免费在线播放| 欧美日韩免费精品| 99国产精品99久久久久久粉嫩| 日韩视频一区二区在线观看 | 欧美金8天国| 最新国产成人在线观看| 99国内精品| 欧美性天天影院| 在线亚洲伦理| 久久国产乱子精品免费女| 国产私拍一区| 久久久天天操| 亚洲激情一区二区三区| 一本到12不卡视频在线dvd| 欧美日本一区二区视频在线观看| 亚洲美女性视频| 欧美一区二区在线免费观看| 国产一区二区成人| 麻豆精品视频在线| 亚洲毛片一区| 久久久久国产精品麻豆ai换脸| 精品福利电影| 欧美日韩国内| 欧美在线在线| 亚洲福利视频一区二区| 亚洲性av在线| 精东粉嫩av免费一区二区三区| 美女诱惑黄网站一区| 一区二区三区精品国产| 久久婷婷久久一区二区三区| 亚洲精品中文字| 国产欧美精品xxxx另类| 裸体素人女欧美日韩| 一本在线高清不卡dvd| 开心色5月久久精品| 99热在这里有精品免费| 国产一区二区三区日韩| 欧美另类极品videosbest最新版本| 中文精品视频| 亚洲电影免费| 久久精品论坛| 亚洲网站啪啪| 在线看一区二区| 国产精品伊人日日| 欧美劲爆第一页| 久久久久国色av免费观看性色| 日韩午夜在线观看视频| 欧美xart系列在线观看| 午夜久久一区| 99精品视频网| 亚洲大片免费看| 国产精品自拍小视频| 欧美人与性动交a欧美精品| 久久精品国产一区二区三| 一区二区三区黄色| 亚洲黄色在线| 欧美激情二区三区| 久久精品一区| 午夜一区不卡| 亚洲香蕉伊综合在人在线视看| 亚洲欧洲综合| 在线日韩中文字幕| 国产午夜精品美女视频明星a级| 欧美日韩精品免费观看视频完整| 久久久久国产一区二区三区| 午夜精品一区二区三区在线视 | 欧美影院一区| 亚洲视频综合在线| 日韩一级欧洲| 亚洲精品国产品国语在线app| 欧美电影免费观看高清| 美女尤物久久精品| 久久亚洲欧洲| 卡通动漫国产精品| 久久人人97超碰人人澡爱香蕉| 午夜精品国产| 亚洲欧美日韩综合国产aⅴ| 亚洲网站啪啪| 亚洲欧美日韩久久精品 | 国产欧美日韩一区| 国产精品美女视频网站| 国产精品久久久久久亚洲毛片| 欧美天天综合网| 国产精品免费网站在线观看| 国产精品美女www爽爽爽| 国产精品高潮呻吟久久av无限| 欧美午夜电影一区| 国产欧美在线视频| 国产一区香蕉久久| 亚洲高清视频在线| 亚洲毛片视频| 亚洲欧美视频| 久久亚洲国产成人| 欧美va日韩va| 日韩一区二区福利| 亚洲欧美国产一区二区三区| 小黄鸭精品aⅴ导航网站入口| 久久精品国产综合精品| 欧美电影打屁股sp| 欧美日韩在线播放一区二区| 国产精品日韩专区| 一区二区视频欧美| 99成人在线| 欧美中文在线字幕| 嫩模写真一区二区三区三州| 亚洲片国产一区一级在线观看| 99视频+国产日韩欧美| 午夜一区二区三视频在线观看| 久久精品一本久久99精品| 欧美成黄导航| 国产精品三级视频| 亚洲国产精品毛片| 亚洲综合国产| 嫩模写真一区二区三区三州| 亚洲精品乱码久久久久久蜜桃91| 亚洲一区二区三区在线观看视频| 久久精品国产亚洲一区二区三区 | 欧美不卡一卡二卡免费版| 欧美日韩在线不卡| 一区久久精品| 亚洲一区免费网站| 欧美不卡一卡二卡免费版| 亚洲午夜三级在线| 欧美成人小视频| 国产午夜亚洲精品不卡| 在线亚洲伦理| 蜜臀va亚洲va欧美va天堂| 亚洲系列中文字幕| 欧美成人按摩| 一区二区三区在线免费视频| 亚洲直播在线一区| 亚洲国产日韩欧美在线99 | 在线亚洲伦理| 欧美激情综合在线|