hdu 1875 畅通project再续(kruskal算法计算最小生成树)
畅通project再续
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 18411 Accepted Submission(s): 5769
如今政府决定大力发展百岛湖,发展首先要解决的问题当然是交通问题,政府决定实现百岛湖的全畅通!
经过考察小组RPRush对百岛湖的情况充分了解后。决定在符合条件的小岛间建上桥,所谓符合条件,就是2个小岛之间的距离不能小于10米。也不能大于1000米。当然,为了节省资金,仅仅要求实现随意2个小岛之间有路通就可以。
当中桥的价格为 100元/米。
输入首先包含一个整数T(T <= 200),代表有T组数据。
每组数据首先是一个整数C(C <= 100),代表小岛的个数。接下来是C组坐标,代表每一个小岛的坐标,这些坐标都是 0 <= x, y <= 1000的整数。
2
2
10 10
20 20
3
1 1
2 2
1000 1000
1414.2
oh!
pid=1232" style="color:rgb(26,92,200); text-decoration:none">1232
1863 1874 1102最小生成树问题。两种算法prim和kruskal。在这里我用的另外一种算法
第一次RE了。。
原来数组太小了。。。CNN!!
分别计算n各小岛各个的距离(小于10大于1000的不要),而且存到结构体eg里面。sort依据距离从小到大排序,然后就用kruskal算法。
最后推断树根是否仅仅有一个。
还是看代码来的实在,有简单凝视
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
using namespace std;
int fa[105],n;
struct node//存贮第一次输入的坐标,一定要是浮点型的
{
double x,y;
}c[105];
struct node1//存贮两个小岛的编号和小岛的距离
{
int a,b;
double l;
}eg[10005];
bool cmp(node1 x,node1 y)//比較函数
{
return x.l<y.l;
}
int find(int x)//查找根而且缩短路径
{
if(fa[x]!=x) fa[x]=find(fa[x]);
return fa[x];
}
void init()//初始化
{
for(int i=0;i<n;i++)
fa[i]=i;
}
int main()
{
int ncase;
scanf("%d",&ncase);
while(ncase--)
{
scanf("%d",&n);
init();
memset(&c,0,sizeof(&c));
memset(&eg,0,sizeof(&eg));
for(int i=0;i<n;i++)
scanf("%lf %lf",&c[i].x,&c[i].y);
int k=0;
for(int i=0;i<n;i++)
for(int j=i+1;j<n;j++)
{
double temp=sqrt(pow(c[i].x-c[j].x,2)+pow(c[i].y-c[j].y,2));
if(temp>=10&&temp<=1000)//假设距离大于等于10小于等于1000
{
eg[k].a=i,eg[k].b=j,eg[k].l=temp;
k++;
}
}
sort(eg,eg+k,cmp);//依据距离排序<span style="white-space:pre"> </span>
double sum=0;//计算最小生成树的和
for(int i=0;i<k;i++)
{
int x=find(eg[i].a);
int y=find(eg[i].b);
if(x!=y)
fa[x]=y,sum+=eg[i].l; }
int count=0;
for(int i=0;i<n;i++)//推断树根个数
if(fa[i]==i)
count++;
if(count!=1)
printf("oh!\n");
else
printf("%.1lf\n",sum*100);
}
return 0;
}
hdu 1875 畅通project再续(kruskal算法计算最小生成树)的更多相关文章
- hdu 1875 畅通工程再续(prim方法求得最小生成树)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1875 /************************************************* ...
- hdu 1875 畅通project再续
链接:hdu 1875 输入n个岛的坐标,已知修桥100元/米,若能n个岛连通.输出最小费用,否则输出"oh!" 限制条件:2个小岛之间的距离不能小于10米,也不能大于1000米 ...
- HDU 1875 畅通工程再续(kruskal)
畅通工程再续 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- HDU 1875 畅通project再续 (最小生成树 水)
Problem Description 相信大家都听说一个"百岛湖"的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其它的小岛时都要通过划小船来实现. 如今政府决定大力发展百岛 ...
- hdoj 1875 畅通project再续【最小生成树 kruskal && prim】
畅通project再续 Problem Description 相信大家都听说一个"百岛湖"的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其它的小岛时都要通过划小船来实现. ...
- HDU 1875 畅通工程再续 (prim最小生成树)
B - 畅通工程再续 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit S ...
- HDU 1875 畅通工程再续 (最小生成树)
畅通工程再续 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- HDU 1875 畅通工程再续 (最小生成树)
畅通工程再续 题目链接: http://acm.hust.edu.cn/vjudge/contest/124434#problem/M Description 相信大家都听说一个"百岛湖&q ...
- HDU 1875 畅通工程再续 (Prim)
题目链接:HDU 1875 Problem Description 相信大家都听说一个"百岛湖"的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其他的小岛时都要通过划小船来实现 ...
随机推荐
- windows 快捷调用
win + x:系统常用管理工具: win + r,或者按下 windows 键,在输入框中输入: services.msc:服务管理: diskmgmt.msc:磁盘管理: devmgmt.msc: ...
- 7.配置文件mocha.opts
转自:http://www.ruanyifeng.com/blog/2015/12/a-mocha-tutorial-of-examples.html Mocha允许在test目录下面,放置配置文件m ...
- 防雪崩利器:熔断器 Hystrix 的原理与使用--转
原文地址:https://segmentfault.com/a/1190000005988895 前言 分布式系统中经常会出现某个基础服务不可用造成整个系统不可用的情况, 这种现象被称为服务雪崩效应. ...
- 利用js与java交互
为了方便网页和应用的交互,安卓系统WebView提供JavaScript网页脚本调用Java类方法的机制.只要调用addJavascriptInterface方法即可映射一个Java对象到JavaSc ...
- RadioButton的drawableTop图片文字不居中
在安卓应用的开发中,一般普通应用用到最多的就是底部放一个RadioGroup实现切换的布局,今天在实现的时候,却出现了底部RadiButton的drawableTop图片及文字无法居中的情况,经过对比 ...
- 《剑指offer》二维数组中的查找
一.题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 二.输入描述 ar ...
- 使用freerdp远程连接Windows桌面(转载)
使用freerdp远程连接Windows桌面 之前使用的是rdesktop,但是由于其不支持NLA认证,便不能登录公司的电脑.为此,现在使用freerdp——这是package的名字,实际的可执行程序 ...
- [NOIP2010提高组]引水入城
题目:洛谷P1514.Vijos P1777.codevs1066. 题目大意:有一个$n×m$的矩阵,每个点都有一个高度,可以在第一行的任意点建立蓄水厂.现在要把水输到最后一行的所有点上,规定水只能 ...
- caioj 1084 动态规划入门(非常规DP8:任务安排)(取消后效性)
这道题的难点在于,前面分组的时间会影响到后面的结果 也就是有后效性,这样是不能用dp的 所以我们要想办法取消后效性 那么,我们就可以把影响加上去,也就是当前这一组加上了s 那么就把s对后面的影响全部加 ...
- BZOJ——T 1612: [Usaco2008 Jan]Cow Contest奶牛的比赛
http://www.lydsy.com/JudgeOnline/problem.php?id=1612 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1 ...