HDU1875 畅通工程再续【最小生成树】
题意:
在这些小岛中建设最小花费的桥,但是一座桥的距离必须在10 -- 1000之间。
思路:
用最小生成树解决吧,就那两个算法。
代码:
prim
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath> using namespace std;
#define N 105
#define inf 0x3f3f3f3f int n,i,j,x[N],y[N];
double map[N][N];
bool vis[N];//标记是否已经放入最小生成树的那个集合里了
double low[N];//记录不在已经加入最小生成树的这个集合里的元素到这个 集合的最小距离 double dis(int i,int j)
{
return sqrt(1.0*(x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]));
} void init()
{
for(i=;i<=n;++i)
cin>>x[i]>>y[i];
for(i=;i<=n;++i)
for(j=;j<=n;++j)
{
map[i][j]=dis(i,j);
if(map[i][j]>||map[i][j]<)
{
map[i][j]=inf;
}
}
} void prim()
{
double sum=;
memset(vis,,sizeof(vis));
int pos=;//从1开始
for(i=;i<=n;++i)//第一次给low赋值
{
low[i]=map[][i];
}
vis[]=;
//已经找到一个点1,再找n-1个
for(i=;i<n;++i)
{
double min=inf;
for(j=;j<=n;++j)
{
if(!vis[j]&&min>low[j])//找下一个点到这个集合的最小值
{
min=low[j];//记下这个最小值
pos=j;//记下这个点
}
}
if(min==inf)
{
cout<<"oh!"<<endl;
return ;
}
sum+=min;
vis[pos]=;//把刚刚找到的这个点加入集合
for(j=;j<=n;++j) //更新low数组
{
if(!vis[j]&&low[j]>map[pos][j])
{
low[j]=map[pos][j];
}
}
}
printf("%.1lf\n",sum*);
} int main()
{
int t;
cin>>t;
while(t--)
{
cin>>n;
init();
prim();
}
return ;
}
kruskal
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
struct Island
{
int x,y;
};
struct node
{
int u,v;
double w;
};
Island arr[];
node edge[];
int per[];
int n;
bool cmp(node a,node b)
{
return a.w<b.w;
}
void init()
{
for(int i=;i<=n;++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 ;
}
return ;
}
int main()
{
int T;
int i,j,k;
double x,y;
scanf("%d",&T);
while(T--)
{ scanf("%d",&n);
init();
for(i=;i<=n;++i)
{
scanf("%d%d",&arr[i].x,&arr[i].y);
}
//m=n*(n-1)/2;
k=;
for(i=;i<=n;++i)//把所有路记录在node结构体中
{
for(j=i+;j<=n;++j)
{
edge[k].u=i;
edge[k].v=j;
x=(arr[j].y-arr[i].y)*(arr[j].y-arr[i].y);
y=(arr[j].x-arr[i].x)*(arr[j].x-arr[i].x);
double temp=sqrt(x+y);
edge[k++].w=temp;
}
}
sort(edge,edge+k,cmp);
double sum=;
for(i=;i<k;++i)
{
if(edge[i].w<=&&edge[i].w>=&&join(edge[i].u,edge[i].v))//如果两个岛的距离不符合要求就会把join(edge[i].u,edge[i].v)短路
{
sum+=edge[i].w;
}
}
int cnt=;
bool flag=;
for(i=;i<=n;++i)//短路了就不会执行了,也就不会连接了,就只需要判断根节点的个数
{
if(i==per[i]) cnt++;
if(cnt>) //不等于1就还有元素(小岛)没连起来,不满足题意
{
flag=;
break;
}
}
if(flag) printf("oh!\n");
else
printf("%.1lf\n",sum*);
}
return ;
}
HDU1875 畅通工程再续【最小生成树】的更多相关文章
- HDU1875——畅通工程再续(最小生成树:Kruskal算法)
畅通工程再续 Description相信大家都听说一个“百岛湖”的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其他的小岛时都要通过划小船来实现.现在政府决定大力发展百岛湖,发展首先要解决的问题当 ...
- hdu1875 畅通工程再续 最小生成树并查集解决---kruskal
http://acm.hdu.edu.cn/showproblem.php?pid=1875 New~ 欢迎“热爱编程”的高考少年——报考杭州电子科技大学计算机学院关于2015年杭电ACM暑期集训队的 ...
- HDU 1875 畅通工程再续 (最小生成树)
畅通工程再续 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- HDU1875 畅通工程再续 (并查集)
畅通工程再续 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- HDU1875 畅通工程再续 2017-04-12 19:52 48人阅读 评论(0) 收藏
畅通工程再续 Time Limit : 2000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Submis ...
- HDU-1875 畅通工程再续(最小生成树+判断是否存在)
http://acm.hdu.edu.cn/showproblem.php?pid=1875 Problem Description 相信大家都听说一个“百岛湖”的地方吧,百岛湖的居民生活在不同的小岛 ...
- hdu1875 畅通工程再续 并查集/最小生成树
相信大家都听说一个“百岛湖”的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其他的小岛时都要通过划小船来实现.现在政府决定大力发展百岛湖,发展首先要解决的问题当然是交通问题,政府决定实现百岛湖的全 ...
- hdu1875 畅通工程再续 暴力+基础最小生成树
#include<cstdio> #include<cmath> #include<algorithm> using namespace std; ; ; ; in ...
- B - 畅通工程再续 最小生成树
相信大家都听说一个“百岛湖”的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其他的小岛时都要通过划小船来实现.现在政府决定大力发展百岛湖,发展首先要解决的问题当然是交通问题,政府决定实现百岛湖的全 ...
随机推荐
- js數組
數組對象創建: var a=new Array(); var b=new Array(1); var a=new Array(“AA“,”AA“): 相關函數: sort()排序,可以進行字面上排序s ...
- codeforces622B
The Time CodeForces - 622B 给你当前的时间(24小时制):HH:MM.输出 x 分钟后的时间是多少?(24小时制) 不明白可以看看例子哦- Input 第一行给出了当前时间, ...
- 浅谈教你如何掌握Linux系统
linux能做什么?相信绝大数人都有这样的疑问.可以玩吃鸡吗?可以玩lol吗? 如果你是以娱乐的名义来评价linux的可用性,对不起,linux可能不适合你,因为linux是一个工具,他是教你聪明的, ...
- BZOJ4652 NOI2016循环之美(莫比乌斯反演+杜教筛)
因为要求数值不同,不妨设gcd(x,y)=1.由提示可以知道,x/y是纯循环小数的充要条件是x·klen=x(mod y).因为x和y互质,两边同除x,得klen=1(mod y).那么当且仅当k和y ...
- python numpy 数组拼接
我就写一下我遇到的,更多具体的请看Python之Numpy数组拼接,组合,连接 >>> aarray([0, 1, 2], [3, 4, 5], [6, 7, ...
- MT【37】二次函数与整系数有关的题
解析: 评:两根式是不错的考虑方向,一方面二次函数两根式之前有相应的经验,另一方面这里$\sqrt{\frac{b^2}{4}-c}$正好和两个根有关系.
- Centos7下Zabbix3.4至Zabbix4.0的升级步骤
点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 Centos7下Zabbix3.4至Zabbix4.0的升级步骤 查看现在centos版本和zab ...
- 自学Aruba2.2-Aruba Web UI --Monitoring面板介绍
点击返回:自学Aruba之路 自学Aruba2.2-Aruba Web UI --Monitoring面板介绍 1. Monitoring面板-NETWORK Network Summary ...
- [luogu2149][bzoj1880][SDOI2009]Elaxia的路线【拓扑排序+最短路+DP】
题目描述 最近,Elaxia和w的关系特别好,他们很想整天在一起,但是大学的学习太紧张了,他们 必须合理地安排两个人在一起的时间. Elaxia和w每天都要奔波于宿舍和实验室之间,他们 希望在节约时间 ...
- JDK源码分析(2)LinkedList
JDK版本 LinkedList简介 LinkedList 是一个继承于AbstractSequentialList的双向链表.它也可以被当作堆栈.队列或双端队列进行操作. LinkedList 实现 ...