hdoj 1875 畅通project再续【最小生成树 kruskal && prim】
畅通project再续
如今政府决定大力发展百岛湖。发展首先要解决的问题当然是交通问题,政府决定实现百岛湖的全畅通!
经过考察小组RPRush对百岛湖的情况充分了解后。决定在符合条件的小岛间建上桥,所谓符合条件,就是2个小岛之间的距离不能小于10米,也不能大于1000米。
当然,为了节省资金。仅仅要求实现随意2个小岛之间有路通就可以。当中桥的价格为 100元/米。
每组数据首先是一个整数C(C <= 100),代表小岛的个数。接下来是C组坐标。代表每一个小岛的坐标。这些坐标都是 0 <= x, y <= 1000的整数。
2
2
10 10
20 20
3
1 1
2 2
1000 1000
1414.2
oh!
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<algorithm>
using namespace std;
int per[111];
double x[111],y[111];
struct node{
int start,end;
double distance;
};
node p[10000];
int cmp(node a,node b) //距离从小到大
{
return a.distance < b.distance;
}
void init()
{
for(int i = 1;i < 111;i++ )
per[i] = i;
}
int find(int x)
{
if(x == per[x])
return x;
return per[x] = find(per[x]);
}
bool join(int x,int y)
{
int fx = find(x);
int fy = find(y);
if(fx != fy) //推断是否成环
{
per[fx] = fy;
return true; //没成环
}
return false;
}
int main()
{
int i,j,k;
int t,n,c;
double d,cost; //一定要注意题目所要求的数据类型
scanf("%d",&t);
while(t--)
{
init();
scanf("%d",&c);
for(i = 1;i <= c; i++)
{
scanf("%lf%lf",&x[i], &y[i]);
}
k = 0;
for(i = 1;i <= c;i++)
{
for(j = i+1;j <= c;j++)
{
d = sqrt( (x[j]-x[i])*(x[j]-x[i])+(y[j]-y[i])*(y[j]-y[i]) );//距离公式
if(d >=10.0 && d <= 1000.0) //一定要筛选完再存进结构体 要不然会WA.
{
p[k].start = i; //起点
p[k].end = j; //终点
p[k].distance = d;//起点到到终点的距离
k++;
}
}
}
sort(p,p+k,cmp); //按距离从小到大排序
int num = 0;
cost = 0.0;
for( i = 0;i < k; i++)
{
if(join(p[i].start, p[i].end))
cost += p[i].distance;
}
for( i = 1;i <= c;i++ )
{
if(per[i]==i)
num++;
if(num > 1) // 及时跳出循环节省时间
break;
}
if(num>1) //无法连接全部小岛
printf("oh!\n");
else
printf("%.1lf\n",100*cost);
}
return 0;
}
===============================切割线======================================
#include<cstdio>
#include<cstring>
#include<cmath>
#define mem(a, b) memset(a, (b), sizeof(a))
#define Wi(a) while(a--)
#define Si(a) scanf("%d", &a)
#define Pi(a) printf("%d\n", (a))
#define Pf(a) printf("%.1lf\n", (a))
#define INF 0x3f3f3f
double map[150][150];
int x[150],y[150];
int n;
double d[150], vis[150];
void prim()
{
mem(vis, 0);
int i, j, k;
double ans = 0, minn;
for(i = 1; i <= n; i++)
d[i] = map[1][i];
vis[1] = 1;
for(i = 1; i < n; i++)
{
k = 1;
minn = INF;
for(j = 1; j <= n; j++)
{
if(!vis[j] && d[j] < minn)
{
minn = d[j];
k = j;
}
}
if(minn == INF){
puts("oh!");return;
}
vis[k] = 1;
ans += minn;
for(j = 1; j <= n; j++)
{
if(!vis[j] && d[j] > map[j][k])
d[j] = map[j][k];
}
}
Pf(ans*100);
}
int main(){
int t; Si(t);
Wi(t){
Si(n);
int i , j, k;
for(i = 1; i <= n; i++)
{
scanf("%d%d", &x[i], &y[i]);
}
for(i = 1; i <= n; i++)
{
for(j = 1; j <= n; j++)
{
double d = sqrt( (x[i]-x[j])*(x[i]-x[j]) + (y[i]-y[j])*(y[i]-y[j]));
if(d >= 10.0 && d <= 1000.0)
map[i][j] = map[j][i] = d;
else
map[i][j] = map[j][i] = INF;
}
map[i][i] = 0;
}
prim();
}
return 0;
}
hdoj 1875 畅通project再续【最小生成树 kruskal && prim】的更多相关文章
- hdu 1875 畅通project再续(kruskal算法计算最小生成树)
畅通project再续 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- HDU 1875 畅通工程再续 (最小生成树)
畅通工程再续 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- HDU 1875 畅通project再续 (最小生成树 水)
Problem Description 相信大家都听说一个"百岛湖"的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其它的小岛时都要通过划小船来实现. 如今政府决定大力发展百岛 ...
- Hdoj 1875.畅通工程再续 题解
Problem Description 相信大家都听说一个"百岛湖"的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其他的小岛时都要通过划小船来实现.现在政府决定大力发展百岛湖 ...
- hdoj 1875 畅通工程再续
题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1875 //9403289 2013-10-24 17:00:49 Accepted 1875 62M ...
- (step6.1.3)hdu 1875(畅通工程再续——最小生成树)
题目大意:本题是中文题,可以直接在OJ上看 解题思路:最小生成树 1)本题的关键在于把二维的点转化成一维的点 for (i = 0; i < n; ++i) { scanf("%d%d ...
- hdu 1875 畅通project再续
链接:hdu 1875 输入n个岛的坐标,已知修桥100元/米,若能n个岛连通.输出最小费用,否则输出"oh!" 限制条件:2个小岛之间的距离不能小于10米,也不能大于1000米 ...
- hdu1875 畅通工程再续 最小生成树并查集解决---kruskal
http://acm.hdu.edu.cn/showproblem.php?pid=1875 New~ 欢迎“热爱编程”的高考少年——报考杭州电子科技大学计算机学院关于2015年杭电ACM暑期集训队的 ...
- HDU 1875 畅通工程再续 (最小生成树)
畅通工程再续 题目链接: http://acm.hust.edu.cn/vjudge/contest/124434#problem/M Description 相信大家都听说一个"百岛湖&q ...
随机推荐
- SPOJ GSS3 Can you answer these queries III ——线段树
[题目分析] GSS1的基础上增加修改操作. 同理线段树即可,多写一个函数就好了. [代码] #include <cstdio> #include <cstring> #inc ...
- BZOJ 4004 [JLOI2015]装备购买 ——线性基
[题目分析] 题目很简单,就是要维护一个实数域上的线性基. 仿照异或空间的线性基的方法,排序之后每次加入一个数即可. 卡精度,开long double 和 1e-6就轻松水过了. [代码] #incl ...
- 【2018.11.23】2018WCTest(7)
向已退役学长致敬! 题目&他的题解 T1 一道睿智题目,正常思路就是时空复杂度均为 $O(n\times 32768)$ 的背包.这个做法不被卡时间却被卡空间,其实就是想让你离线处理询问,然后 ...
- Office 中的各种小tips(更新中)
1.Word 中打字输入会擦掉之后原有字符,出现“吃字”的情况? 要将“改写”切换为“插入”,最简单的方法就是点击键盘上小键盘旁边的“insert”键. 其实仔细观察的话,在word文档下方,会看到如 ...
- php那些坑
1.创建数组不是new array(),是$aaa=array(),没有new,数组可以传入键值$aaa=array("key"=>"value"); 2 ...
- Java线程的学习_线程池
系统启动一个新线程需要很高的成本,因为它涉及与操作系统交互.在这种情况下,使用线程池可以很好地提高性能,尤其是当程序中需要创建大量生存期很短暂的线程时. 线程池在系统启动时即创建大量空闲的线程,程序将 ...
- msp430项目编程50
msp430综合项目---gsm无线采集传输平台系统50 1.电路工作原理 2.代码(显示部分) 3.代码(功能实现) 4.项目总结
- SecureCRT 配置文件中 找密码
打开本地电脑如下路径 C:\Users\XXX\AppData\Roaming\VanDyke\Config\Sessions 找到配置文件. 运行命令:python SecureCRTDecrypt ...
- 不拖控件的asp.net编程方法——第1回
以前写的asp.net程序基本上都用了webfrom的控件编写的,当然有个好处就是易入门.快速效率高,但感觉自己这了几个小系统,还是没学到什么东西,感觉心里没底,因为都是封装好的东西,拿来就用的,功能 ...
- android 环境变量配置,以及sdcard配置
第一步,打开环境变量配置窗口.右击计算机,属性-高级系统设置-环境变量. 第二步,添加android系统环境变量.在系统变量下,选择path,点击编辑,然后在最前面输入android sdk开发工具, ...