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

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>
            久久久久中文| 国产精品久久久久久久久免费| 国产欧美日韩精品专区| 亚洲欧美久久久久一区二区三区| 亚洲卡通欧美制服中文| 欧美日韩精品免费观看| 亚洲一区二区三区色| 亚洲——在线| 黄色日韩精品| 亚洲国产成人91精品| 欧美人妖另类| 欧美一区二区三区播放老司机| 欧美一区二区三区视频在线观看| 国内久久婷婷综合| 亚洲电影av在线| 国产精品美女午夜av| 猫咪成人在线观看| 欧美日韩福利| 欧美专区在线播放| 欧美.com| 久久久久成人精品免费播放动漫| 久久免费午夜影院| 亚洲一线二线三线久久久| 久久国产欧美日韩精品| 99成人在线| 欧美一区二区三区在线观看| 亚洲日本激情| 欧美一区二区大片| 日韩亚洲视频在线| 久久精品亚洲一区二区三区浴池| 亚洲国产小视频| 性久久久久久| 亚洲一级在线观看| 免费欧美日韩国产三级电影| 欧美一级播放| 欧美日韩一区二区视频在线观看 | 国产精品―色哟哟| 欧美国产极速在线| 国产午夜精品在线观看| 亚洲精品午夜| 亚洲国产经典视频| 久久福利一区| 亚洲欧美一区二区三区在线| 欧美精品www| 欧美成年人视频网站欧美| 国产日韩精品视频一区二区三区| 亚洲国产成人一区| 亚洲国产成人在线| 久久国产精品久久久久久久久久 | 亚洲电影观看| 国内精品久久久久久久影视麻豆 | 国产精品久久久久久久久久妞妞 | 欧美与欧洲交xxxx免费观看| 亚洲视频一区二区| 欧美精品videossex性护士| 毛片基地黄久久久久久天堂| 国产日韩欧美一二三区| 亚洲深夜影院| 亚洲网站在线观看| 免费亚洲电影在线观看| 久久国产加勒比精品无码| 国产精品久久久久毛片软件 | 欧美一级欧美一级在线播放| 亚洲欧美激情视频| 欧美精品国产一区| 亚洲精品欧美专区| 99精品视频免费在线观看| 欧美激情2020午夜免费观看| 欧美国内亚洲| 亚洲精品免费网站| 欧美激情麻豆| 亚洲精品美女| 一区二区三区成人精品| 欧美日韩精品高清| 亚洲一二三区视频在线观看| 香蕉成人伊视频在线观看 | 国产精品国产馆在线真实露脸 | 亚洲福利av| 一本色道久久| 国产精品久久久久久亚洲调教| 在线午夜精品自拍| 久久精品最新地址| 亚洲电影免费观看高清完整版在线| 久热精品在线| 日韩香蕉视频| 欧美一区二区三区视频在线| 国产视频一区在线| 久久天堂av综合合色| 亚洲激情一区| 亚洲欧美在线磁力| 伊人激情综合| 欧美日韩大陆在线| 性欧美办公室18xxxxhd| 欧美激情第9页| 亚洲永久精品国产| 黄网站免费久久| 欧美另类变人与禽xxxxx| 亚洲一区二区三区免费观看| 噜噜噜久久亚洲精品国产品小说| 亚洲精品永久免费精品| 国产精品日韩欧美一区二区| 久久先锋影音| 亚洲视频免费| 亚洲大胆视频| 久久久久久精| 一区二区三区成人精品| 国内精品久久久久国产盗摄免费观看完整版| 久久综合99re88久久爱| 亚洲深夜福利网站| 亚洲电影中文字幕| 久久精品国产久精国产思思| 亚洲精品孕妇| 伊人精品久久久久7777| 国产精品v片在线观看不卡 | 亚洲欧美日韩电影| 亚洲精品社区| 欧美成人免费在线观看| 欧美一区二区网站| 亚洲一二三区在线观看| 最新国产拍偷乱拍精品| 国产日韩一区| 国产精品草莓在线免费观看| 浪潮色综合久久天堂| 欧美一区观看| 亚洲永久免费av| 99成人在线| 亚洲激情校园春色| 欧美国产综合| 欧美国产激情| 欧美插天视频在线播放| 久久久欧美精品sm网站| 性色av香蕉一区二区| 亚洲天堂av电影| 亚洲私人黄色宅男| 中日韩高清电影网| 夜夜嗨网站十八久久| 亚洲精品在线看| 亚洲人成毛片在线播放| 亚洲国产精品成人一区二区| 黄色在线一区| 亚洲大片在线观看| 136国产福利精品导航| 亚洲高清久久| 亚洲国产经典视频| 亚洲国产日韩一级| 亚洲精品日产精品乱码不卡| 亚洲激情av在线| 亚洲日本成人在线观看| 亚洲区一区二区三区| 亚洲精品免费观看| 一区二区三区 在线观看视频 | 国产自产v一区二区三区c| 国产欧美日韩一区二区三区| 国产精品一区免费视频| 韩国一区二区在线观看| 一区视频在线播放| 亚洲黄色视屏| 一本色道久久综合亚洲精品不卡 | 亚洲大胆av| 亚洲日本理论电影| 亚洲午夜国产一区99re久久| 一区二区三区四区蜜桃| 亚洲一区二区在线视频| 香蕉久久精品日日躁夜夜躁| 久久久精品免费视频| 欧美高清自拍一区| 欧美午夜精品理论片a级按摩| 国产精品视频福利| 一区二区三区在线观看国产| 亚洲国产视频a| 亚洲女同性videos| 久久综合色影院| 亚洲高清视频的网址| 一区二区三区国产盗摄| 久久国内精品自在自线400部| 欧美激情第三页| 国产欧美韩日| 亚洲九九精品| 久久久久久穴| 亚洲精品一区在线观看| 亚洲欧美影院| 欧美极品欧美精品欧美视频| 国产美女扒开尿口久久久| 亚洲人成人99网站| 久久久免费精品视频| 亚洲老板91色精品久久| 久久av一区二区三区漫画| 欧美日韩亚洲网| 亚洲福利电影| 久久国产高清| 一区二区三区不卡视频在线观看 | 久久久久久9| 国产精品久久久亚洲一区| 亚洲国产天堂久久综合| 欧美在线观看一区| 99国产精品国产精品毛片| 免播放器亚洲一区| 国产一区二区日韩精品欧美精品| a4yy欧美一区二区三区| 欧美大片免费看|