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相关推荐

  1. HDU1874 畅通工程续【Dijkstra算法】

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  2. hdu1874 畅通工程续 floyd入门题学习

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  3. HDU-1874畅通工程续( 最短路)

    畅通工程续 Problem Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比 ...

  4. HDU-1874 畅通工程续 (最短路径启蒙题)

    hdu 1874比较基础,拿来练各种刚学会的算法比较好,可以避免好多陷阱,典型的最短路模板题 畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memor ...

  5. hdu 1874 畅通工程续(求最短距离,dijkstra,floyd)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1874 /************************************************* ...

  6. HDU 1874 畅通工程续 最短路

    畅通工程续 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Description 某 ...

  7. hdu 1874畅通工程续(基础Floyd)

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  8. 【最短路算法】dijkstra,SPFA和folyd

    在了解本知识点之前,首先要了解图的建立,也就是邻接表和邻接矩阵. 邻接矩阵适用于稠密图 邻接表适用于稀疏图 目录 单源最短路问题 dijkstra算法 SPFA算法 folyd算法 最小生成树 拓扑排 ...

  9. 【floyd】HDU 1874 畅通project续

    之后的题解偏重有用/总结性质,尽量理解算法本身而不是题,时间复杂度什么的也能够放放. 非常久之前做过这个题,当时使用dijkstra做的,关于几个最短路算法,分类的话能够分为下面几种. 1.单源最短路 ...

最新文章

  1. 【2019/4/30】周进度报告
  2. 面试官问:如果MySQL的自增 ID 用完了,怎么办?
  3. mysql 5.6 互为主从_mysql5.6主从同步,互为主从配置
  4. 【ASP.NET开发】ASP.NET(MVC)三层架构知识的学习总结
  5. arcgis导入excel数据_ArcGIS批量导入数据
  6. bytebuf池_图文分析ByteBuf是什么
  7. redis 高级实用教程
  8. 【线性代数本质】2:线性组合和线性相关和线性无关以及张成的空间
  9. 07 熟练使用Console类实现从控制台输入输出数据 1214
  10. WebBrowser自动点击链接 广告自动点击 Ads Auto Click
  11. Windows 命令行及Git操作
  12. WinDbg / SOS Cheat Sheet
  13. MacOs中Docker与宿主机网络互通问题解决
  14. 数字表达_高级表白密码,教你如何用数字表达出我爱你
  15. C ++入门系列博客一 最初的起点 — Hello World
  16. 配置VSS2005的Internet访问(转)
  17. 图像处理——matlab人脸识别(1)
  18. Golang环境配置及第三方库安装使用(至关重要的防踩坑篇)
  19. 统计分析用户信息量的工具Flurry的使用
  20. chrome插件帮助你在12306官网刷票

热门文章

  1. 有多少智能,就有多少人工?人工智能背后的数据标注师
  2. 2010年—2018年中国电商成交额排名
  3. 阿联酋的科技野心:AI或将成为新“石油”
  4. 迁移学习全面指南:概念、项目实战、优势、挑战
  5. Python正则表达式常用的15个符号整理
  6. 如何看懂一个深度学习的项目代码
  7. 汪劲:生命系统中的非平衡物理学
  8. Meta旨在打造世界上最快的人工智能超级计算机
  9. 人工智能可以发现数据中隐藏的物理规律
  10. 拥有“上帝视角”是怎样的体验?高分多模卫星首批影像成果发布