HDU1875+Prim模板
https://cn.vjudge.net/problem/HDU-1875
Input输入包括多组数据。输入首先包括一个整数T(T <= 200),代表有T组数据。
每组数据首先是一个整数C(C <= 100),代表小岛的个数,接下来是C组坐标,代表每个小岛的坐标,这些坐标都是 0 <= x, y <= 1000的整数。
Output每组输入数据输出一行,代表建桥的最小花费,结果保留一位小数。如果无法实现工程以达到全部畅通,输出”oh!”.Sample Input
2
2
10 10
20 20
3
1 1
2 2
1000 1000
Sample Output
1414.2
oh!
#include<iostream>
#include<stdio.h>
#include<bits/stdc++.h>
const int inf=;
using namespace std;
int x[],y[];
double w[][],dis[];
int n,m;
bool vis[];
double weight(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 prim()
{
int i,j,k;
bool flag=;
double sum=,tmp;
for(int i=;i<=m;i++)
dis[i]=inf;
dis[]=;
for(i=;i<=m;i++)
{
tmp=inf;
for(j=;j<=m;j++)
if(!vis[j]&&tmp>dis[j])
{
tmp=dis[j];
k=j;
}
if(tmp==inf){flag=;break;}
vis[k]=;
sum+=tmp;
int y;
for(j=;j<=m;j++)
{
if(!vis[j]&&dis[j]>w[k][j])
dis[j]=w[k][j];
} }
if(flag)
printf("%.1f\n",sum*);
else
printf("oh!\n");
} int main()
{
cin>>n;
for(int i=;i<n;i++)
{
cin>>m;
memset(x,,sizeof x);
memset(y,,sizeof y);
memset(vis,,sizeof vis);
for(int j=;j<=m;j++)
cin>>x[j]>>y[j];
for(int k=;k<=m;k++)
for(int l=;l<=m;l++)
{
double p=weight(k,l);
if(p>=&&p<=)
w[k][l]=w[l][k]=p;
else
w[k][l]=w[l][k]=inf;
}
prim();
}
return ;
}
思路:
使用Prim求解最小生成树。
注意点:
1.一定要记得给每个数组初始化,一开始忘记给vis[]初始化了,导致调试了好久。
2.用memset的时候要注意类型,我给double赋极大值错误地使用了memset(dis,0x3f,sizeof dis);后来想到double类型是8个字节的,int是四个字节的(这是四字节赋极大值的方法,赋给8个字节的double类型的数得到的结果不一样),因为memset是按字节赋值的。这么给double赋值得到了一个约等于0的数,与预想的结果不同,导致错误。
Prim模板(解决最小生成树问题):
void prim()
{
int i,j,k,tmp;
memset(dis,0x3f,sizeof dis);
dis[]=;
for(i=;i<=n;i++)
{
tmp=inf;
for(j=;j<=n;j++)
if(!vis[j]&&tmp>dis[j])
{
tmp=dis[j];
k=j;
}//找到最小距离的节点
vis[k]=;
for(j=;j<=n;j++)
{
if(!vis[j]&&dis[j]>g[k][j])
dis[j]=g[k][j];
}//更新最短距离
}
}
HDU1875+Prim模板的更多相关文章
- HDU 1223 还是畅通工程(最小生成树prim模板)
一个很简单的prim模板,但虽然是模板,但也是最基础的,也要脱离模板熟练打出来 后期会更新kruskal写法 #include<iostream> #include<cstdio&g ...
- Kruskal && Prim模板
1. Kruskal(并查集模板): /* Kruskal:并查集实现,记录两点和距离,按距离升序排序,O (ElogE) */ struct Edge { int u, v, w; bool ope ...
- prim模板题
题目链接:http://acm.hrbeu.edu.cn/index.php?act=problem&id=1223 #include <cstdio> #include < ...
- prim模板
]; int n; ][]; ]; int prim(){ int i,j,mi,v; ;i<n;i++){ d[i]=map[][i]; vis[i]=; } ;i<=n;i++){ m ...
- 最小生成树(kruskal模版 Prim模板)
http://acm.sdut.edu.cn/sdutoj/showproblem.php?pid=2144&cid=1186 最小生成树,最重要的是了解思想 稠密图用Prim,稀疏图用Kru ...
- poj 1258 Agri-Net prim模板 prim与dijkstra的区别
很裸地求最小生成树的题目.题意就不多说了,最重要的就是记录一下学会了prim算法. 初学prim,给我的第一感觉就是和dijkstra好像啊,感觉两者的区别还是有的: 1:prim是求最小生成树的算法 ...
- prim 模板
#include<cstdio> #include<vector> #include<cstring> #include<set> #define ma ...
- 最小生成树模板【kruskal & prim】
CDOJ 1966 Kruskal 解法 时间复杂度O(mlogm) m为边数,这里主要是边排序占时间,后面并查集还好 #include <cstdio> #include <cst ...
- 最小生成树(次小生成树)(最小生成树不唯一) 模板:Kruskal算法和 Prim算法
Kruskal模板:按照边权排序,开始从最小边生成树 #include<algorithm> #include<stdio.h> #include<string.h> ...
随机推荐
- 为什么要用lock 【readonly】object?为什么不要lock(this)?
一. 为什么要用lock,lock了什么? 当我们使用线程的时候,效率最高的方式当然是异步,即各个线程同时运行,其间不相互依赖和等待.但当不同的线程都需要访问某个资源的时候,就需要同步机制了.也就是说 ...
- MySQL两种存储引擎: MyISAM和InnoDB
MySQL两种存储引擎: MyISAM和InnoDB 简单总结 MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Me ...
- js 从URL上获取参数
//获取匹配的 function getUrlParam(name) { var reg = new RegExp("(^|&)" + ...
- jQuery操作table数据上移、下移和置顶
jQuery 操作table中的tr换行的步骤如下: 1.获取当前tr var $tr = $(this).parents("tr"); 2.移动tr //上移 $tr.prev( ...
- HDFS 2.7.4中hdfs-site.xml参数未配置引发的一些异常
生产上部署了HDFS 2.7.4,最近遇到了一些异常,记录下来备忘: 一.dfs.datanode.directoryscan.throttle.limit.ms.per.sec DataNode运行 ...
- VMware 创建VMware9虚拟机及设置详细教程
创建VMware9虚拟机及设置详细教程 by:授客 QQ:1033553122 1.点击Create a New Virtual Machine图标按钮,或者file->new virtual ...
- ListView 添加 HeaderView常见错误
1.addHeaderView异常: 最近在做通讯录开发时使用ListView,发现一个奇怪的问题:当添加一个ImageView 作为HeaderView时,发现ImageView长宽始终是1:1的大 ...
- 本地用maven搭建SpringMvc+redis集成
---恢复内容开始--- 首先本地需要搭建私服,简单说一下搭建私服的步骤 1.为什么使用Nexus 如果没有私服,我们所需的所有构件都需要通过maven的中央仓库和第三方的Maven仓库下载到本地,而 ...
- 记一款bug管理系统(bugdone.cn)的开发过程(2) -如何做好登录界面
一. 做了一个大胆的决定,官网首页便是登录界面 BugDone,Bug管理工具的定位就是一款非常易用的工具,所以我们没有像其它平台那样进官网首页都是一些功能和业务的介绍. 我们觉得方便用户快速进入工作 ...
- SQL Server 全文索引的硬伤(转载)
本文关键字:SQL Server全文索引.CONTAINS.FREETEXT.CONTAINSTABLE.FREETEXTTABLE等谓词. 想象这样一个场景:在DataBase_name.dbo.T ...