hdu 1875 畅通工程再续

点击打开链接hdu 1875

/*
1思路:最小生成树+prime(模板题)
*/
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
#define MAXN 110
#define INF 0xFFFFFFF

int t , c;
double ans;
double lowcost[MAXN];
double G[MAXN][MAXN];
struct Point{
    int x;
    int y;
}p[MAXN];

void init(){
    for(int i = 1 ; i <= c ; i++){
       for(int j = 1 ; j <= c ; j++){
         double tmp_x = (p[i].x-p[j].x)*(p[i].x-p[j].x);
         double tmp_y = (p[i].y-p[j].y)*(p[i].y-p[j].y);
         double tmp =  sqrt(tmp_x + tmp_y);
         if(tmp < 10 || tmp > 1000)
           G[i][j] = INF;
         else
           G[i][j] = tmp;
       }
    }
}

void Prime(){
     int pos;
     double min;
     int vis[MAXN];
     memset(vis , 0 , sizeof(vis));
     init();
     vis[1] = 1;
     ans = 0;
     for(int i = 1 ; i <= c ; i++)
        lowcost[i] = G[1][i];
     for(int i = 1 ; i <= c ; i++){
        min = INF;
        for(int j = 1 ; j <= c ; j++){
           if(!vis[j] && min > lowcost[j]){
              pos = j;
              min = lowcost[j];
           }
        }
        if(min == INF)
          break;
        ans += min;
        vis[pos] = 1;
        for(int j = 1 ; j <= c ; j++){
           if(!vis[j] && lowcost[j] > G[pos][j])
             lowcost[j] = G[pos][j];
        }
     }
     if(G[1][c] != INF)
       printf("%.1lf\n" , ans*100);
     else
       printf("oh!\n");
}

int main(){
   // freopen("input.txt" , "r" , stdin);
    scanf("%d" , &t);
    while(t--){
       scanf("%d" , &c);
       for(int i = 1 ; i <= c ; i++)
          scanf("%d%d" , &p[i].x , &p[i].y);
       Prime();
    }
    return 0;
}
时间: 2024-11-03 18:11:19

hdu 1875 畅通工程再续的相关文章

hdu 1863 畅通工程

点击打开链接hdu 1863 1思路:最小生成树+Prime 2注意:n是边数,m是点数.当m为0的时候输出的数"?". 代码: #include<algorithm> #include<iostream> #include<cstdio> #include<cstring> using namespace std; #define MAXN 110 #define INF 0xFFFFFFF int n , m; long long a

HDU1232畅通工程

畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 25274    Accepted Submission(s): 13174 Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府"畅通工程"的目标是使全省任何两个城镇间都可以实现交通(但不一定有

acm-ACM HDU1879继续畅通工程 提交RE.求各路大神帮忙看一下哪儿错了

问题描述 ACM HDU1879继续畅通工程 提交RE.求各路大神帮忙看一下哪儿错了 题目大意: 求最小生成树的权值和,并输出.已经修建的路(已经连上的边)是不会算入到最后的ANS中. Input 测试输入包含若干测试用例.每个测试用例的第1行给出村庄数目N ( 1< N < 100 ):随后的 N(N-1)/2 行对应村庄间道路的成本及修建状态,每行给4个正整数,分别是两个村庄的编号(从1编号到N),此两村庄间道路的成本,以及修建状态:1表示已建,0表示未建. 当N为0时输入结束. Samp

HDU1233还是畅通工程

还是畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 21896    Accepted Submission(s): 9768 Problem Description 某省调查乡村交通状况,得到的统计表中列出了任意两村庄间的距离.省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相

网络稳定投诉降低河南联通“双畅通工程”见成效

曾庆斌 吕志英 本报讯 (记者 曾庆斌 吕志英) 河南联通积极推进"宽带和移动双畅通"工程,网络运营质量有了明显提高,进一步提升了服务质量,降低了移动和宽带客户投诉量."双畅通"一期工程自2008年11月份启动,到今年5月完工,投资总额达3亿元."双畅通"工程的目标是通过实施线路整治.宽带设备优化等工作,提升宽带上网的速度与稳定性:通过优化移动网络,进一步改善网络深度覆盖与话音质量,提高手机用户感知. 在宽带畅通工程方面,河南联通相继开展了线路整

hd1879继续畅通工程【最小生成树】

继续畅通工程 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 13795    Accepted Submission(s): 6013 Problem Description 省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).现得到城镇道路统计表,表中列

hd1874畅通工程续

畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 28207    Accepted Submission(s): 10209 Problem Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行

hd1863畅通工程

畅通工程 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 16997    Accepted Submission(s): 7136 Problem Description 省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).经过调查评估,得到的统计表中列出

hdu 1879 继续畅通工程

点击打开链接1879 /* 1思路:最小生成树+kruskal 2注意把已经建好的合并 */ #include<iostream> #include<algorithm> #include<cstdio> #include<cstring> using namespace std; #define MAXN 110 #define INF 0XFFFFFFF int n , m , ans; int father[MAXN]; int rank[MAXN];