hdu1874 畅通project续 最短路 floyd或dijkstra或spfa
Problem Description
某省自从实行了非常多年的畅通project计划后。最终修建了非常多路。只是路多了也不好,每次要从一个城镇到还有一个城镇时,都有很多种道路方案能够选择。而某些方案要比还有一些方案行走的距离要短非常多。这让行人非常困扰。
如今,已知起点和终点。请你计算出要从起点到终点,最短须要行走多少距离。
Input
本题目包括多组数据,请处理到文件结束。
每组数据第一行包括两个正整数N和M(0< N<200,0 < M<1000),分别代表现有城镇的数目和已修建的道路的数目。
城镇分别以0~N-1编号。
接下来是M行道路信息。每一行有三个整数A,B,X(0<=A,B < N,A!=B,0< X <10000),表示城镇A和城镇B之间有一条长度为X的双向道路。
再接下一行有两个整数S,T(0<=S,T < N),分别代表起点和终点。
Output
对于每组数据,请在一行里输出最短须要行走的距离。假设不存在从S到T的路线,就输出-1.
Sample Input
3 3
0 1 1
0 2 3
1 2 1
0 2
3 1
0 1 1
1 2
Sample Output
2
-1
Author
linle
Source
2008浙大研究生复试热身赛(2)——全真模拟
起点到终点的最短路 这里给出3种算法。Floyd。dijkstra和spfa
从提交的代码得速度来看。dijkstra>spfa>Floyd
可是别人都说spfa最快。。。(我就不知道了)
folyd不推荐使用。由于他最慢。,数据大一点的话更不行。
。(只是他最简单)
(1)Floyd
#include<cstdio>
#include<cmath>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
#include<vector>
#include<map>
#include<stack>
#pragma comment(linker,"/STACK:102400000,102400000")
#define pi acos(-1.0)
#define EPS 1e-6
#define INF (1<<28)
using namespace std;
int cost[205][205];
bool used[205];
int n,m;
int d[205];
void floyd()
{
for(int k=0;k<n;k++)
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
cost[i][j]=min(cost[i][j],cost[i][k]+cost[k][j]);
}
int main()
{
while(scanf("%d %d",&n,&m)!=EOF)
{
int i,j;
for(i=0;i<n;i++)
{
cost[i][i]=0;
for(j=0;j<n;j++)
{
if(i!=j) cost[i][j]=INF;
}
}
int a,b,value,start,endl;
for(i=0;i<m;i++)
{
scanf("%d %d %d",&a,&b,&value);
if(cost[a][b]>value) cost[a][b]=cost[b][a]=value; //多条路的情况。
}
scanf("%d %d",&start,&endl);
floyd();
if(cost[start][endl]!=INF) printf("%d\n",cost[start][endl]);
else printf("-1\n");
}
return 0;
}
2:dijkstra
#include<cstdio>
#include<cmath>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
#include<vector>
#include<map>
#include<stack>
#pragma comment(linker,"/STACK:102400000,102400000")
#define pi acos(-1.0)
#define EPS 1e-6
#define INF (1<<28)
using namespace std;
int cost[205][205];
bool used[205];
int n,m;
int d[205];
void dijkstra(int s)
{
fill(d,d+n,INF);
fill(used,used+n,false);
d[s]=0;
while(true)
{
int v=-1;
for(int u=0;u<n;u++)
{
if(!used[u]&&(v==-1||d[u]<d[v])) v=u;
}
if(v==-1) break;
used[v]=true;
for(int u=0;u<n;u++)
{
d[u]=min(d[u],d[v]+cost[v][u]);
}
}
}
int main()
{
while(scanf("%d %d",&n,&m)!=EOF)
{
int i,j;
for(i=0;i<n;i++)
{
cost[i][i]=0;
for(j=0;j<n;j++)
{
if(i!=j) cost[i][j]=INF;
}
}
int a,b,value,start,endl;
for(i=0;i<m;i++)
{
scanf("%d %d %d",&a,&b,&value);
if(cost[a][b]>value) cost[a][b]=cost[b][a]=value; //多条路的情况。
}
scanf("%d %d",&start,&endl);
dijkstra(start);
if(d[endl]!=INF) printf("%d\n",d[endl]);
else printf("-1\n");
}
return 0;
}
3:spfa
#include<cstdio>
#include<cmath>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
#include<vector>
#include<map>
#include<stack>
#pragma comment(linker,"/STACK:102400000,102400000")
#define pi acos(-1.0)
#define EPS 1e-6
#define INF (1<<28)
using namespace std;
int cost[205][205];
bool used[205];
int n,m;
int d[205];
void SPFA(int src,int des)
{
int i;
for(i=0;i<n;i++) d[i]=INF;
memset(used,false,sizeof(used));
queue<int> myqueue;
while(!myqueue.empty()) myqueue.pop();//清空队列
d[src]=0;
used[src]=1;
myqueue.push(src);
int tmp;
while(!myqueue.empty())
{
tmp=myqueue.front();
myqueue.pop();
used[tmp]=0;
for(i=0;i<n;i++)
if(d[i]>d[tmp]+cost[tmp][i])
{
d[i]=d[tmp]+cost[tmp][i];
if(!used[i])
{
used[i]=1;
myqueue.push(i);
}
}
}
}
int main()
{
while(scanf("%d %d",&n,&m)!=EOF)
{
int i,j;
for(i=0;i<n;i++)
{
cost[i][i]=0;
for(j=0;j<n;j++)
{
if(i!=j) cost[i][j]=INF;
}
}
int a,b,value,start,endl;
for(i=0;i<m;i++)
{
scanf("%d %d %d",&a,&b,&value);
if(cost[a][b]>value) cost[a][b]=cost[b][a]=value; //多条路的情况。
}
scanf("%d %d",&start,&endl);
SPFA(start,endl);
if(d[endl]!=INF) printf("%d\n",d[endl]);
else printf("-1\n");
}
return 0;
}
hdu1874 畅通project续 最短路 floyd或dijkstra或spfa的更多相关文章
- HDU1874畅通project续 dijkstra&&floyd
畅通project续 http://acm.hdu.edu.cn/showproblem.php?pid=1874 Time Limit: 3000/1000 MS (Java/Others) ...
- hdu1874 畅通project续(求最短路径)
畅通project续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- HDU 1874 畅通project续 (最短路径)
畅通project续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- hdoj 1874 畅通project续【SPFA】
畅通project续 Time Limit : 3000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Su ...
- HDOJ 1874 畅通project续
畅通project续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- hdu1874畅通工程续(floyd)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- HDU1874畅通工程续(floyd||dijkstra)
看了看floyd和dijkstra,然后就找了两个练习来捉 #include<iostream> #include<stdio.h> #include<string.h& ...
- HDU-1874 畅通工程续 (最短路径启蒙题)
hdu 1874比较基础,拿来练各种刚学会的算法比较好,可以避免好多陷阱,典型的最短路模板题 畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memor ...
- hdu 1874 畅通工程续(求最短距离,dijkstra,floyd)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1874 /************************************************* ...
随机推荐
- linux指令快速复制粘贴[龟速更新中]
由于有经常碰到要输入linux指令,但是却忘记了的情况.在家里我把常用的命令放到Xshell的快速命令集,但是在很多情况下不在家,可能用的他人电脑,以及在非Win环境下使用ssh时没有xshell使用 ...
- Node实现简单的注册时后端的MVC模型架构
实现一个简单的注册界面后端MVC模型架构 第一步:在生成的express框架的app.js中添加一个路由,代码如下:var api = require('./routes/api'); app.use ...
- EXPIREAT
EXPIREAT key timestamp EXPIREAT 的作用和EXPIRE类似,都用于为key设置生存时间. 不同在于EXPIREAT命令接受都时间参数是UNIX时间戳(unix times ...
- Spring Cloud学习笔记【九】配置中心Spring Cloud Config
Spring Cloud Config 是 Spring Cloud 团队创建的一个全新项目,用来为分布式系统中的基础设施和微服务应用提供集中化的外部配置支持,它分为服务端与客户端两个部分.其中服务端 ...
- Use Uncertainty As a Driver
 Use Uncertainty As a Driver Kevlin Henney ConFRonTEd WiTH TWo opTionS, most people think that the ...
- hdu 思维风暴
点击打开链接 偶然在杭电上看到的题目,数学题.好像是一道六年级奥赛题目,反正我是没有想出来,也知道往那上面想.就是找不到规律啊.学习了网上的方法, 这道题须要求出来多添加的点,就是与之前每条边添加的点 ...
- ios学习:swift中实现分享到微博、facebook,twitter等
在swift中打开分享功能原来是如此的简单. 1.首先须要 import Social 2.在分享button事件以下 var controller:SLComposeViewController = ...
- 习题(3-3) 计算(a+b)*c的值
题目 - 习题(3-3) 计算(a+b)*c的值 来源 计算概论B 2010 描写叙述 计算表达式(a+b)*c的值,当中a, b, c均为整数,且a,b,c的值介于-10000和10000之间( ...
- 关于APP上架制作二维码相关
1.安卓版本APP上架并生成二维码问题:安卓版本上架国内市场,这个情况比较复杂一些,比如百度,网址是以上传APP生成的一个编号来进行的,每次升级更新后都发生了变化,也就相当于每次升级后网址发生改变(比 ...
- Android TextureView简易教程
如果你想显示一段在线视频或者任意的数据流比如视频或者OpenGL 场景,你可以用android中的TextureView做到. TextureView的兄弟SurfaceView 应用程序的视频或者o ...