首页 > Web开发 > 详细

UVA 10369 Arctic Network

时间:2014-08-04 20:39:27      阅读:342      评论:0      收藏:0      [点我收藏+]

题目来源:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=1310

      最小生成树问题,Prim算法在这种给出坐标的情况相对Kruskal算法优势还是很大。

 1 /*AC 19ms*/
 2 #include<stdio.h>
 3 #include<stdlib.h>
 4 #include<math.h>
 5 #include<string.h>
 6 #include<algorithm>
 7 #define INF 1000000
 8 const int maxn=500+5;
 9 double lowdist[maxn];
10 bool in[maxn];
11 int x[maxn],y[maxn];
12 double dist(int x1,int y1,int x2,int y2)
13 {
14     return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
15 }
16 void prim(int n)
17 {
18     lowdist[1]=0;
19     for(int i=2;i<=n;i++){
20         lowdist[i]=dist(x[1],y[1],x[i],y[i]);
21         in[i]=false;
22     }
23     in[1]=true;
24     for(int i=1;i<n;i++){
25         double mindist=INF;
26         int j=1;
27         for(int k=1;k<=n;k++)
28         if(mindist>lowdist[k] && !in[k]){
29             mindist=lowdist[k];
30             j=k;
31         }
32         in[j]=true;
33         for(int k=1;k<=n;k++){
34             double temp=dist(x[j],y[j],x[k],y[k]);
35             if(lowdist[k]>temp && !in[k])
36                 lowdist[k]=temp;
37         }
38     }
39 }
40 int main()
41 {
42     int t,m,n;
43     scanf("%d",&t);
44     while(t--){
45         scanf("%d%d",&m,&n);
46         for(int i=1;i<=n;i++)
47             scanf("%d%d",&x[i],&y[i]);
48         prim(n);
49         std::sort(lowdist+1,lowdist+1+n);
50         printf("%0.2f\n",lowdist[n-m+1]);
51     }
52     return 0;
53 }

bubuko.com,布布扣

UVA 10369 Arctic Network,布布扣,bubuko.com

UVA 10369 Arctic Network

原文:http://www.cnblogs.com/BMESwimming/p/3890588.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!