hdu 1875 给出每个结点的坐标 权值为两点间的距离 (MST)

Sample Input
2
2
10 10 //坐标
20 20
3
1 1
2 2
1000 1000

Sample Output
1414.2   //最小权值和*100  保留1位小数
oh!       //不连通

 

prim

 1 # include <iostream>
 2 # include <cstdio>
 3 # include <cstring>
 4 # include <algorithm>
 5 # include <cmath>
 6 # define LL long long
 7 using namespace std ;
 8 
 9 const int INF=0x3f3f3f3f;
10 const int MAXN=110;
11 bool vis[MAXN];
12 double lowc[MAXN];
13 int n ;
14 double cost[MAXN][MAXN] ;
15 
16 struct poin
17 {
18     int x ;
19     int y ;
20 }p[110];
21 
22 double Prim()//点是0~n-1
23 {
24     double ans=0;
25     memset(vis,false,sizeof(vis));
26     vis[0]=true;
27     for(int i=1;i<n;i++)lowc[i]=cost[0][i];
28     for(int i=1;i<n;i++)
29     {
30         double minc=INF;
31         int p=-1;
32         for(int j=0;j<n;j++)
33             if(!vis[j]&&minc>lowc[j])
34             {
35                 minc=lowc[j];
36                 p=j;
37             }
38             if(minc==INF)return -1;//原图不连通
39             ans+=minc;
40             vis[p]=true;
41             for(int j=0;j<n;j++)
42                 if(!vis[j]&&lowc[j]>cost[p][j])
43                     lowc[j]=cost[p][j];
44     }
45     return ans;
46 }
47 
48 int main()
49 {
50 
51    // freopen("in.txt","r",stdin) ;
52     int T ;
53     scanf("%d" , &T) ;
54     while(T--)
55     {
56         scanf("%d" , &n) ;
57         int i , j ;
58         for (i = 0 ; i < n ; i++)
59             for (j = 0 ; j < n ; j++)
60                cost[i][j] = INF ;
61         for (i = 0 ; i < n ; i++)
62             scanf("%d %d" , &p[i].x , &p[i].y) ;
63         for (i = 0 ; i < n ; i++)
64             for (j = i+1 ; j < n ; j++)
65             {
66                 double t = sqrt((double)(p[i].x - p[j].x) * (p[i].x - p[j].x) + (p[i].y - p[j].y) * (p[i].y - p[j].y)) ;
67                 if (t <10.0 || t > 1000.0)
68                     continue ;
69                 cost[i][j] = t ;
70                 cost[j][i] = t ;
71             }
72         double k = Prim() ;
73         if (k == -1)
74             printf("oh!\n") ;
75         else
76             printf("%.1lf\n" , k*100) ;
77 
78     }
79     return 0 ;
80 }
View Code

 

posted @ 2015-06-14 15:45  __Meng  阅读(269)  评论(0编辑  收藏  举报