洛谷 1265
来源:互联网 发布:c语言代码大全下载 编辑:程序博客网 时间:2024/05/25 12:22
这道题比较麻烦的一点是有条件2的限制,不过,我们可以证明条件2是不可能发生的,假设A要修AC,C要修BC,B要修AB,那么我们通过它们的距离关系推出矛盾。没有了条件2的限制,我们还要有条件3,我们考虑如果我们直接用最小生成树的话是否可以,假设我们当前已经组成了K个连通块,那么在连接任意两个连通块时,选择的边一定是连通这两个连通块的最小边,因此我们可以直接用prim。
#include<cstdio>#include<cstring>#include<algorithm>#include<cmath>using namespace std;#define maxn 5005int x[maxn],y[maxn],n,pos;double ans,low[maxn];bool mst[maxn];double sqr(int xx){return (double)xx*xx;}double jl(int u,int v){return sqrt(sqr(x[u]-x[v])+sqr(y[u]-y[v]));}int main(){scanf("%d",&n);for (int i=1;i<=n;i++) scanf("%d%d",x+i,y+i);mst[1]=1;pos=1;low[0]=1e11;for (int i=1;i<=n;i++) low[i]=jl(pos,i);for (int i=1;i<n;i++) {pos=0;for (int j=1;j<=n;j++)if (low[j]<low[pos]&&!mst[j]) pos=j;mst[pos]=1;ans+=low[pos];for (int j=1;j<=n;j++) if (!mst[j]) low[j]=min(low[j],jl(pos,j));}printf("%.2lf\n",ans);return 0;}
0 0
- 洛谷 1265
- 洛谷1265 公路修建
- [洛谷1265] 公路修建 - prim
- POJ 1265
- POJ 1265
- poj 1265
- UESTC 1265
- poj 1265
- LightOJ 1265
- poj 1265
- HAUTOJ 1265
- 洛谷
- 洛谷
- 洛谷
- 1265 卡片之和
- pku 1265 Area
- Poj 1265 Area
- poj 1265(pick 定理)
- Hadoop 伪分布式配置
- 【hdu 1058】Humble Numbers
- Android 应用程序启动过程分析 (用SysTrace 跟踪分析)
- 王小草【深度学习】笔记第二弹--细说卷积神经网络
- Android eclipse中项目调试
- 洛谷 1265
- netty 对 http 的实现
- 程序员在上海之四
- 在windows下打出tar.gz的尝试
- SQL
- struts
- 第八周训练5三色球问题
- web入门(tomcat+http)
- 设计模式之 适配器模式