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 /************************************************* ...
随机推荐
- windows下laravel5安装
第一步:安装composer 网上教程非常多,自行百度 第二步:使用composer create-project laravel/laravel learnlaravel5 5.0.22 ...
- Android基础新手教程——4.3.2 BroadcastReceiver庖丁解牛
Android基础新手教程--4.3.2 BroadcastReceiver庖丁解牛 标签(空格分隔): Android基础新手教程 本节引言: 上节我们对BroadcastReceiver已经有了一 ...
- TI C66x DSP 四种内存保护问题 -之- 外设訪问corePac内部资源时的内存保护问题
外设訪问corePac内部资源(L1,L2)时的内存保护等问题请參考以下两个blog.已经叙述的非常具体. "TI C66x DSP 系统events及其应用 - 2"," ...
- Magento--修改已存在的订单的运费
遇到一种情况,需要在下单后再由管理员添加订单运费,然后顾客再付款.那么问题来了,如何给订单添加运费呢?下面是一段代码,可以实现该功能: $orderId = 'your order id';$orde ...
- POJ 1682 DP
原创: http://www.cnblogs.com/proverbs/archive/2012/10/03/2711151.html 超高仿: http://blog.csdn.net/mars_c ...
- CORS support in Spring Framework--官方
原文地址:https://spring.io/blog/2015/06/08/cors-support-in-spring-framework For security reasons, browse ...
- 15:Challenge 11(主席树裸题)
总时间限制: 10000ms 单个测试点时间限制: 1000ms 内存限制: 262144kB 描述 给一个长为N的数列,有M次操作,每次操作是以下两种之一: (1)修改数列中的一个数 (2)求 ...
- Linux常用视频播放器
1.SMplayer是一款跨平台的视频播放工具,可以支持大部分的视频和音频文件.它支持音频轨道切换.允许调节亮度.对比度.色调.饱和度.伽玛值,按照倍速.4倍速等多种速度回放.还可以进行音频和字幕延迟 ...
- Huawei交换机VRP配置介绍
一.命令视图• 用户视图<Huawei>• 系统视图 [Huawei]• 接口视图 [Huawei-GigabitEthernet0/0/1]• 协议视图 [Huawei-rip-1]• ...
- css line-height详解
行高指的是文本行的基线间的距离(更简单来说,行高是指文字尺寸与行距之间的和). 而基线(Base line),指的是一行字横排时下沿的基础线, 基线并不是汉字的下端沿,而是英文字母x的下端沿,同时还有 ...