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

现在,已知起点和终点,请你计算出要从起点到终点,最短需要行走多少距离。

 
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
 
 dijkstra代码:
 #include <stdio.h>
#define N 210
#define INF 100000000
int n, m;
int vis[N], dis[N], cost[N][N];
int min(int x, int y)
{
return x < y ? x : y;
}
void dijkstra(int s, int t)
{
int u, v;
for(u = ; u < n; u++)
{
vis[u] = ;
dis[u] = INF;
}
dis[s] = ;
while(true)
{
v = -;
for(u = ; u < n; u++)
if(!vis[u] && (v == - || dis[u]<dis[v]))
v = u;
if(v == -)
break;
vis[v] = ;
for(u = ; u < n; u++)
dis[u] = min(dis[u], dis[v]+cost[v][u]);
if(v == t)
break;
}
if(dis[t] == INF)
printf("-1\n");
else
printf("%d\n", dis[t]);
return ;
}
int main()
{
int s, t;
while(~scanf("%d%d", &n, &m))
{
//if(n<0 || n>=200 || m<0 || m>= 1000)
// break;
int i, j, a, b, c;
for(i = ; i < n; i++)
for(j = ; j < n; j++)
cost[i][j] = INF;
while(m --)
{
scanf("%d%d%d", &a, &b, &c);
if(cost[a][b] > c)
cost[a][b] = cost[b][a] = c;
}
scanf("%d%d", &s, &t);
dijkstra(s, t);
}
return ;
}

spfa代码:

 #include <stdio.h>
#include <queue>
#include <string.h>
#define INF 0x3f3f3f3f
using namespace std;
int n, m, cnt, t;
int vis[], used[], dis[];
int head[];
struct node
{
int from, to, val, next;
}edge[];
int add(int x, int y, int z)
{
edge[cnt].from = x;
edge[cnt].to = y;
edge[cnt].val = z;
edge[cnt].next = head[x];
head[x] = cnt++;
}
void spfa(int s)
{
priority_queue <int> q;
memset(vis, , sizeof(vis));
memset(dis, INF, sizeof(dis));
memset(used, , sizeof(used));
vis[s] = ;
dis[s] = ;
q.push(s);
while(!q.empty())
{
int x = q.top();
q.pop();
vis[x] = ;
for(int i = head[x]; i != -; i = edge[i].next)
{
int y = edge[i].to;
if(dis[y] > dis[x]+edge[i].val)
{
dis[y] = dis[x]+edge[i].val;
q.push(y);
vis[y] = ;
used[y]++;
if(used[y] > n)
return ;
}
}
}
if(q.empty())
{
if(dis[t]==INF)
printf("-1\n");
else
printf("%d\n", dis[t]);
}
return ;
}
int main()
{
int s, a, b, x;
while(~scanf("%d%d", &n, &m))
{
cnt = ;
memset(head, -, sizeof(head));
while(m--)
{
scanf("%d%d%d", &a, &b, &x);
add(a, b, x);
add(b, a, x);
}
scanf("%d%d", &s, &t);
spfa(s);
}
return ;
}

floyd算法:

 #include <stdio.h>
#define INF 0x3f3f3f3f
#define N 210
int dis[N][N];
int n, m;
void init()
{
for(int i = ; i < n; i++)
for(int j = ; j < n; j++)
if(j == i)
dis[i][j] = ;
else
dis[i][j] = INF;
}
void floyd()
{
for(int k = ; k < n; k++)
for(int i = ; i < n; i++)
{
if(dis[i][k] != INF)
{
for(int j = ; j < n; j++)
if(dis[i][j] > dis[i][k] + dis[k][j])
dis[i][j] = dis[i][k] + dis[k][j];
}
}
}
int main()
{
int a, b, x;
while(~scanf("%d%d", &n, &m))
{
init();
while(m--)
{
scanf("%d%d%d", &a, &b, &x);
if(dis[a][b] > x)
dis[a][b] = dis[b][a] = x;
}
floyd();
int s, t;
scanf("%d%d", &s, &t);
if(dis[s][t] != INF)
printf("%d\n", dis[s][t]);
else
printf("-1\n");
}
return ;
}

hdoj 1874 畅通工程续的更多相关文章

  1. hdoj 1874 畅通工程续【dijkstra算法or spfa算法】

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

  2. hdoj 1874 畅通工程续(单源最短路+dijkstra)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 思路分析:该问题给定一个无向图.起始点和终点,要求求出从起始点到终点的最短距离: 使用Dijks ...

  3. ACM: HDU 1874 畅通工程续-Dijkstra算法

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

  4. hdu 1874 畅通工程续

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1874 畅通工程续 Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过 ...

  5. HDU 1874畅通工程续(迪杰斯特拉算法)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 畅通工程续 Time Limit: 3000/1000 MS (Java/Others)     ...

  6. HDU 1874 畅通工程续-- Dijkstra算法详解 单源点最短路问题

    参考 此题Dijkstra算法,一次AC.这个算法时间复杂度O(n2)附上该算法的演示图(来自维基百科): 附上:  迪科斯彻算法分解(优酷) problem link -> HDU 1874 ...

  7. hdu 1874 畅通工程续 Dijkstra

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 题目分析:输入起点和终点,顶点的个数,已连通的边. 输出起点到终点的最短路径,若不存在,输出-1 ...

  8. HDU 1874 畅通工程续【Floyd算法实现】

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

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

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

随机推荐

  1. MyEclipse转换Eclipse项目无法启动问题(转)

    将myeclipse中开发的动态web项目直接引入到eclipse中继续开发,启动tomcat时会发出警告,更重的问题是你想启动的项目不知哪里去了,没有读取到配置文件:       警告: [SetP ...

  2. flask 添加日志

    def add_error_handler(app): for exception in default_exceptions: app.register_error_handler(exceptio ...

  3. Oracle死锁产生的原因和解决办法

    如果有两个会话,每个会话都持有另一个会话想要的资源,此时就会发生死锁.用下面实验来说明死锁的产生原因和解决办法.SESSION1:SQL> create table t2 as select * ...

  4. HTC ONE里面一个非常奇怪的问题。。。调用kSOAP出错

    也是在某统计网站上看到了我们的APP爆出了这么一个bug: java.lang.NoSuchFieldError: No instance field headerOut of type [Lorg/ ...

  5. C++ 约瑟夫环问题

    约瑟夫环比较经典了 已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围.从编号为k的人开始报数,数到m的那个人出列:他的下一个人又从1开始报数,数到m的那个人又出列:依此规律重复下去,直 ...

  6. [转] Making GTFS query more convenient

    url:http://ontrakinfo.wordpress.com/2012/10/29/making-gtfs-query-more-convenient/ 这简直说出了我的心声. I have ...

  7. Shell_参数替换(転)

    From: http://www.cnblogs.com/yjf512/archive/2013/06/03/3114803.html Bash中的$符号的作用是参数替换,将参数名替换为参数所代表的值 ...

  8. 一步步编写avalon组件02:分页组件

    本章节,我们做分页组件,这是一个非常常用的组件.grid, listview都离不开它.因此其各种形态也有. 本章节教授的是一个比较纯正的形态,bootstrap风格的那种分页栏. 我们建立一个ms- ...

  9. apache+tomcat分布式搭建

    windows 下Apache和tomcat整合 负载均衡session共享 准备工作: 1. Apache 2.2.4 下载地址:http://cztele1.skycn.com/down/apac ...

  10. linq 对Sum()函数的支持

    首先看一段SQL语句: SELECT SUM(TASKAPPR) AS APPRCOUNT, SUM(TASKLOCKED) AS LOCKEDCOUNT, SUM(TASKCHECKED) AS C ...