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> ...
随机推荐
- Django中连接redis
1. 安装 pip install django-redis 2. settings中配置 CACHES = { "default": { "BACKEND": ...
- python内置函数每日一学 -- abs()
abs(x) 官方文档解释: Return the absolute value of a number. The argument may be an integer or a floating p ...
- HDU5036 Explosion(期望 bitset)
题意 题目链接 Sol 和cf上的一道题几乎一摸一样 首先根据期望的线性性,可以转化为求每个点的期望打开次数,又因为每个点最多会被打开一次,只要算每个点被打开的概率就行了 设\(anc[i]\)表示\ ...
- 【查找数字x第k为上的数字】
#include<stdio.h> #include<math.h> // 求x用10进制表示时的数位长度 int len(int x){ ) ; )+; } // 取x的第k ...
- 如何解决Your project contains C++ files but it is not using a supported native build system
最近因为项目需要下载Android终端模拟器(Android-Terminal-Emulator)源码进行调试编译,编译过程中出现报错 Error:Execution failed for task ...
- Python+Selenium笔记(十四)鼠标与键盘事件
(一) 前言 Webdriver高级应用的API,允许我们模拟简单到复杂的键盘和鼠标事件,如拖拽操作.快捷键组合.长按以及鼠标右键操作,都是通过使用webdriver的Python API 中的Ac ...
- CSS 小结笔记之滑动门技术
所谓的滑动门技术,就是指盒子背景能够自动拉伸以适应不同长度的文本.即当文字增多时,背景看起来也会变长. 大多数应用于导航栏之中,如微信导航栏: 具体实现方法如下: 1.首先每一块文本内容是由a标签与s ...
- JSON教程基础
一.基础简介 二.JSON 语法 三.JSON 使用 一.基础简介 1.JSON:JavaScript 对象表示法(JavaScript Object Notation). JSON 是存储和交换文本 ...
- android kl文件
android kl(key layout)文件是一个映射文件,是标准linux与anroid的键值映射文件,kl文件可以有很多个,但是它有一个使用优先级: /system/usr/keylayout ...
- DELL MD3200i存储控制器解锁方法
DELL MD3200i存储控制器解锁方法 现有一台DELL MD3200i存储,因种种原因导致控制器被锁定,这里是刚出厂的一台存储,出现这个问题让我们都很困惑,只能怀疑DELL公司的问题. 这台存储 ...