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畅通project续 dijkstra&amp;&amp;floyd

    畅通project续 http://acm.hdu.edu.cn/showproblem.php?pid=1874 Time Limit: 3000/1000 MS (Java/Others)    ...

  2. hdu1874 畅通project续(求最短路径)

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

  3. HDU 1874 畅通project续 (最短路径)

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

  4. hdoj 1874 畅通project续【SPFA】

    畅通project续 Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Su ...

  5. HDOJ 1874 畅通project续

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

  6. hdu1874畅通工程续(floyd)

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

  7. HDU1874畅通工程续(floyd||dijkstra)

    看了看floyd和dijkstra,然后就找了两个练习来捉 #include<iostream> #include<stdio.h> #include<string.h& ...

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

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

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

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

随机推荐

  1. 【UVa 12563】Jin Ge Jin Qu hao

    [Link]: [Description] KTV给你T秒的唱歌时间; 你有n首一定要唱的歌; 然后有一首很变态的歌有678s,你想在T秒结束之前唱一下这首歌; 因为这样的话,你能尽量晚地走出KTV( ...

  2. Java基础学习总结(23)——GUI编程

    一.AWT介绍 所有的可以显示出来的图形元素都称为Component,Component代表了所有的可见的图形元素,Component里面有一种比较特殊的图形元素叫Container,Containe ...

  3. 配置TL-WVR45G企业路由动态地址

    1.打开浏览器,在地址栏输入http://192.168.1.1. 2.输入默认用户名密码:admin,登录. 3.[基本设置]->[lan设置]->[lan设置]  ip地址改成:192 ...

  4. Java 8 时间日期库的20个使用演示样例

    除了lambda表达式,stream以及几个小的改进之外,Java 8还引入了一套全新的时间日期API,在本篇教程中我们将通过几个简单的任务演示样例来学习怎样使用Java 8的这套API.Java对日 ...

  5. linux下u盘检測程序

           获得U盘的插入或者拔取得信息的传统方法是在内核级执行hotplug程序.相关參数通过环境变量传递过来,再由hotplug通知其它关注hotplug的应用程序,可是效率比較低.      ...

  6. vue29-vue2.0组件通信_recv

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. POJ 3184 DP+剪枝

    思路: 先找到每i头奶牛能在的位置 (一段区间) 记为L[i]和R[i] f[j]表示在位置j取到的最小值 每回在范围内更新一哈 //By SiriusRen #include <cstdio& ...

  8. angular4自定义组件非input元素实现ngModel双向数据绑定

    在angular里我们一般都是给input元素添加[(ngModel)]="value"实现数据双向绑定,如果想实现自定义的组件上实现ngModel双向数据绑定应该怎么办呐... ...

  9. Linux Cgroups

    目录 Linux Cgroups Cgroups中的三个组件 三个组件的关系 Kernel接口 Docker是如何使用Cgroups的 Go语言实现Cgroups限制容器资源 Linux Cgroup ...

  10. pwd---以绝对路径的方式显示用户当前工作目录

    pwd命令以绝对路径的方式显示用户当前工作目录.命令将当前目录的全路径名称(从根目录)写入标准输出.全部目录使用/分隔.第一个/表示根目录,最后一个目录是当前目录.执行pwd命令可立刻得知您目前所在的 ...