hdu 2066 ( 最短路) Floyd & Dijkstra & Spfa
http://acm.hdu.edu.cn/showproblem.php?pid=2066
今天复习了一下最短路和最小生成树,发现居然闹了个大笑话-----我居然一直写的是Floyd,但我自己一直以为这是Dijkstra---我居然一直把两个算法
记的是混的,还居然一直没有被别人发现,真是个大乌龙
好了,看看这道题,赤裸裸的最短路水题,首先来个Floyd的,把城市看成点,将连通的的点赋值为给定的时间,未连通的赋值为很大,这是个无向的关系
然后就是三个循环,以一个点为媒介,把每个点遍历一遍,比较找出点连通的最小值就行,稍微优化一点点就不会超时了
code
#include<cstdio>
#include<algorithm>
#define inf 1000000005
using namespace std;
int mp[][],q[];
void jjc()
{
int i,j;
for (i=;i<=;i++){
for (j=;j<=;j++){
if (i==j) mp[i][j]=;
else mp[i][j]=inf;
}
}
}
int min(int x,int y){
if (x<y) return x;
else return y;
}
int main()
{
int t,s,d,c,i,j,k,w,mx,a,b,mn;
while (~scanf("%d %d %d",&t,&s,&d))
{
jjc();
mx=;mn=inf;
while (t--)
{
scanf("%d %d %d",&a,&b,&c);
if (mp[a][b]>c)
mp[a][b]=mp[b][a]=c;
if (a>mx) mx=a; 没有给定范围,所以找范围
if (b>mx) mx=b;
if (a<mn) mn=a;
if (b<mn) mn=b;
}
for (k=mn;k<=mx;k++){
for (i=mn;i<=mx;i++){
if (mp[i][k]>=inf) continue; //稍微优化一点点
for (j=mn;j<=mx;j++){
mp[i][j]=min(mp[i][j],mp[i][k]+mp[k][j]);
}
}
}
for (i=;i<=s;i++)
scanf("%d",&q[i]);
int ans=inf;
while (d--)
{
scanf("%d",&w);
for (i=;i<=s;i++)
{
if (mp[q[i]][w]<ans)
ans=mp[q[i]][w];
}
}
printf("%d\n",ans);
}
return ;
}
然后是Dijkstra的, Floyd是把任意两点的最短距离都求了出来,而Dijkstra只是求了特定的起点与所有点之间的最短路,一般情况而言,后者要快于前者,具体用哪种根据题目而定
按照距离从小到大的顺序,找出从给定起点能够到达的下一点,每找到一个这样的点,然后更新其余点之间的距离
code
#include<cstdio>
#define inf 100000005
using namespace std;
int map[][],vis[],dis[];
int st[],sr[];
int mn,mx;
int min(int x,int y)
{
if (x<y) return x;
else return y;
}
void jjc()
{
int i,j;
for (i=;i<=;i++){
for (j=;j<=;j++){
if (i==j) map[i][j]=;
else map[i][j]=inf;
}
}
}
void dijkstra(int x)
{
int i,pos,j,q;
for (i=mn;i<=mx;i++)
{
dis[i]=map[x][i];
vis[i]=;
}
vis[x]=;
for (i=mn;i<=mx;i++)
{
q=inf;pos=x;
for (j=mn;j<=mx;j++)
if (!vis[j]&&dis[j]<q)
{
pos=j;
q=dis[j];
}
vis[pos]=;
for (j=mn;j<=mx;j++)
dis[j]=min(dis[j],dis[pos]+map[pos][j]);
}
}
int main()
{
int t,s,d,a,b,c,i,j;
while (~scanf("%d %d %d",&t,&s,&d))
{
jjc();
mx=,mn=inf;
while (t--)
{
scanf("%d %d %d",&a,&b,&c);
if (map[a][b]>c)
map[a][b]=map[b][a]=c;
if (a>mx) mx=a;
if (b>mx) mx=b;
if (a<mn) mn=a;
if (b<mn) mn=b;
}
for (i=;i<=s;i++)
scanf("%d",&st[i]);
for (i=;i<=d;i++)
scanf("%d",&sr[i]);
int ans=inf;
for (i=;i<=s;i++)
{
dijkstra(st[i]);
for (j=;j<=d;j++)
if (dis[sr[j]]<ans)
ans=dis[sr[j]];
}
printf("%d\n",ans);
}
return ;
}
队列储存,广搜版的spfa
code
#include<cstdio>
#include<cstring>
#include<queue>
#define inf 0x3fffffff
using namespace std;
int map[][],vis[],dis[];
int st[],sr[];
int mn,mx,s,d;
void jjc()
{
int i,j;
for (i=;i<=;i++){
for (j=;j<=;j++){
if (i==j) map[i][j]=;
else map[i][j]=inf;
}
}
}
int spfa()
{
int num,i;
memset(vis,,sizeof(vis));
for (i=mn;i<=mx;i++)
dis[i]=inf;
queue<int> q;
for (i=;i<=s;i++)
{
dis[st[i]]=;
q.push(st[i]);
}
while(!q.empty())
{
num=q.front();
q.pop();
vis[num]=;
for (i=mn;i<=mx;i++)
{
if (dis[i]>dis[num]+map[num][i])
{
dis[i]=dis[num]+map[num][i];
if (vis[i]==)
{
vis[i]=;
q.push(i);
}
}
}
}
int p=inf;
for (i=;i<=d;i++)
{
if (p>dis[sr[i]]) p=dis[sr[i]];
}
return p;
}
int main()
{
int t,a,b,c,i,j;
while (~scanf("%d %d %d",&t,&s,&d))
{
jjc();
mx=,mn=inf;
while (t--)
{
scanf("%d %d %d",&a,&b,&c);
if (map[a][b]>c)
map[a][b]=map[b][a]=c;
if (a>mx) mx=a;
if (b>mx) mx=b;
if (a<mn) mn=a;
if (b<mn) mn=b;
}
for (i=;i<=s;i++)
scanf("%d",&st[i]);
for (i=;i<=d;i++)
scanf("%d",&sr[i]);
int ans=spfa();
printf("%d\n",ans);
}
return ;
}
hdu 2066 ( 最短路) Floyd & Dijkstra & Spfa的更多相关文章
- HDU 2066 最短路floyd算法+优化
http://acm.hdu.edu.cn/showproblem.php?pid=206 题意 从任意一个邻居家出发 到达任意一个终点的 最小距离 解析 求多源最短路 我想到的是Floyd算法 但是 ...
- 最短路(floyd/dijkstra/bellmanford/spaf 模板)
floyd/dijkstra/bellmanford/spaf 模板: 1. floyd(不能处理负权环,时间复杂度为O(n^3), 空间复杂度为O(n^2)) floyd算法的本质是dp,用dp[k ...
- HDU - 2544最短路 (dijkstra算法)
HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...
- HDu 2544 最短路【dijkstra & floyed & SPFA 】
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- hdu 2544 最短路 (dijkstra,floyd)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目大意:找到两点间最短的距离值. 代码一:(dijkstra算法) #include < ...
- 最短路问题 Floyd+Dijkstra+SPFA
参考博客:https://blog.csdn.net/qq_35644234/article/details/60875818 题目来源:http://acm.hdu.edu.cn/showprobl ...
- HDU Today HDU杭电2112【Dijkstra || SPFA】
http://acm.hdu.edu.cn/showproblem.php?pid=2112 Problem Description 经过锦囊相助,海东集团最终度过了危机,从此.HDU的发展就一直顺风 ...
- find the safest road HDU杭电1596【Dijkstra || SPFA】
pid=1596">http://acm.hdu.edu.cn/showproblem.php?pid=1596 Problem Description XX星球有非常多城市,每一个城 ...
- HDU 2544 最短路 【Dijkstra模板题】
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=2544 思路:最短路的模板题 Dijkstra 算法是一种类似于贪心的算法,步骤如下: 1.当到一个点时, ...
随机推荐
- C#自定义控件:如果定义控件的事件
我做了一个控件: 在控件上面添加了一个 richTextBox1 系统控件 我想要的效果时,如果点击我的控件,就执行 用户自定义的 控件的 onClick 事件 而控件的工作过程时,如果点击我的控件, ...
- UILabel的一些属性
1.0 lineBreakMode 1.1.0 NSLineBreakByWordWrapping = 0, 以字符为显示单位显示,后面部分省略不显示 NSLineBreakByCharWrapp ...
- 解决:python 连接Oracle 11g 报错:ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务
其次,将查询到的service_name替换sid即可:conn=cx_Oracle.connect('hr/admin@localhost:1521/EE.oracle.docker')
- webuploader.js
PHP 多图上传,图片批量上传插件,webuploader.js,百度文件上传插件(案例教程) WebUploader作用: 使用WebUploader还可以批量上传文件.支持缩略图等等众多参数选项 ...
- redis滴
Redis 可用于内存存储,也可以基于持久化存储 Key-Value的形式存储. Redis的数据结构 1.字符串(string) 2.字符串列表(lists) 3.字符串集合(sets) 4.有序字 ...
- redis异常Redis:java.util.NoSuchElementException: Unable to validate object at
前两天项目上线的时候遇到了redis的一个问题,在测试环境的时候项目运行正常,项目一上线redis便开始抛异常. redis.clients.jedis.exceptions.JedisConnect ...
- html中表单的应用
2.表单 ***** 表单作用: 用于显示.收集信息,并将信息提交到服务器 表单两大部分: 1.实现数据交互的可见界面元素,即表单控件 2.提交表单后的处理操作 1.如何实现表单 语法:<for ...
- git ssh免登陆,以及ssh config
git去连接github或gitlab上的远程仓库,可以使用ssh方式,也可以使用git的账号密码登录 这里介绍使用ssh方式实现免登陆(第一步和第二步即可实现) 第一步:生成ssh秘钥 ssh- ...
- HTML图片热区map area的用法(转)
<area>标记主要用于图像地图,通过该标记可以在图像地图中设定作用区域(又称为热点),这样当用户的鼠标移到指定的作用区域点击时,会自动链接到预先设定好的页面.其基本语法结构如下: 1 & ...
- 第四章 栈与队列(c4)栈应用:中缀表达式求值