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> ...
随机推荐
- SpingBoot —— 多线程
Spring 通过任务执行器(TaskExecutor)来实现多线程和并发编程.使用ThreadPoolTaskExecutor可实现一个基于线程池的TaskExecutor.而实际开发中任务一般是非 ...
- python的小数据池 is和== 以及再谈编码
---恢复内容开始--- 1. 小数据池, id() 小数据池针对的是: int, str, bool 在py文件中几乎所有的字符串都会缓存. id() 查看变量的内存地址 # a = 10 # b ...
- 【代码笔记】iOS-给密码进行加密
一,工程图. 二,代码. #import "ViewController.h" #import "Base64CodeByteFunc.h" @interfac ...
- Echarts之悬浮框中的数据排序
Echarts非常强大,配置也非常的多,有很多细节需要深入研究.详解一下关于悬浮框中的数据排序问题 悬浮框的数据排序默认是根据series中的数据位置排序的,在我们想自定义排序时,在echarts的配 ...
- ajax请求json数据跨域问题(转)
一.后台代理技术 由服务器端向跨域下的网站发出请求,再将请求结果返回给前端,成功避免同源策略的限制. 具体操作如下: 1.在localhost:81/a.html中,向同源下的某个代理程序发出请求 $ ...
- WOSA/XFS PTR Form解析库—FormRule.h
#ifndef _FORMRULE_H_#define _FORMRULE_H_ #include <XFSPTR.H>#include <string>#include &l ...
- SwipeRefreshLayout嵌套ScrollView实现下拉刷新
API doc:http://developer.android.com/reference/android/support/v4/widget/SwipeRefreshLayout.html 首先须 ...
- window平台搭建Hudson服务器
1.1 环境 Microsoft Windows server 2008 x64 1.2 资源下载 TortoiseSVN-1.7.11.23600-x64-svn-1.7.8.msi h ...
- SQL Server 查询表的字段对应描述、数据类型、长度
create procedure proc_view_cloumns ( ) ) AS select b.name,a.value,c.name, b.max_length from sys.exte ...
- MySQL binlog group commit--commit stage
说明: 1.process_commit_stage_queue:调用调用ha_commit_low->innobase_commit进入innodb层依次提交 2. process_after ...