畅通工程续(Dijkstra算法)
对Dijkstra算法不是很熟悉,写一下思路,希望通过写博客加深理解
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
Sample Input
0 1 1
0 2 3
1 2 1
0 2
3 1
0 1 1
1 2
#include <stdio.h>
#define M 210
#define INF 0x3f3f3f
int arr[M][M], vis[M], dis[];
int n, m;
void Dijkstra(int src)
{
for(int i = ; i < n; i++)
{
vis[i] = ;
dis[i] = arr[src][i];
}
int tmp, k;
vis[src] = ;
dis[src] = ;
for(int i = ; i < n; i++)
{
tmp = INF;
for(int j = ; j < n; j++)
{
if(!vis[j] && tmp > dis[j])
{
tmp = dis[j];
k = j;
}
}
vis[k] = ;
for(int j = ; j < n; j++)
{
if(!vis[j] && dis[j] > arr[k][j] + dis[k])
dis[j] = arr[k][j] + dis[k];
}
}
}
int main()
{
int s, t, u, v, w;
while(~scanf("%d%d", &n, &m))
{
for(int i = ; i < n; i++)
{
for(int j = ; j < n; j++)
arr[i][j] = INF;
}
for(int i = ; i < m; i++)
{
scanf("%d%d%d", &u, &v, &w);
if(arr[u][v] > w)
arr[u][v] = arr[v][u] = w;
}
scanf("%d%d", &s, &t);
Dijkstra(s);
if(dis[t] == INF)
printf("-1\n");
else
printf("%d\n", dis[t]);
}
return ;
}
上一个代码是我以前参考别人的代码写的,今天又看了这道题,自己写了代码
刚开始一直wrong answer ,竟然一直找不到原因,后来发现我没有考虑从本城市到本城市的情况,初始化的时候arr[i][i] = 0
因为这个,wrong answer 10发,真是醉了
/*
问题:假设所有城市编号0到n-1,给出城市的数目n,已经修的路的数目m,m行给出m条路中a城和b成的距离x
输入出发城市s和目标城市t,问从出发城市到目标城市的最短路线
如果没有路,输出-1
分析:把出发的点s带入Dijkstra算法进行计算,算出所有点到src的最短距离,输出arr[src][t]即可
代码块1:初始化
1:把所有点之间的距离初始化为无穷,
2:别忘了把自己到自己的距离初始化为0(因为这个原因wrong answer 10 发,真的够了)
3:录入输入的城市a到城市b的距离x,如果x小于原本存储的arr[a][b](也就是a城市到b城市的距离)那么就更新a城市到b城市的距离
代码块2:Dijkstra算法:
1:把所有的城市标记为临时的
2:共有n个城市,先把出发的城市标记为永久的,因为每次把一个城市标记为临时的所以还要循环n-1次来标记其他的城市,直到所有城市都为永久
3:每次的循环中找到所有城市中距离起点最近的城市k,并把这个城市标记为永久,更新其他所有城市,假设为"i"到到起点的距离为min(arr[s][k]+arr[k][i], arr[s][i]);
这样就找到了所有城市距离起点s的最短距离,输出arr[s][t]即可
*/
代码2:
#include <stdio.h>
#include <string.h>
#include <algorithm>
#define M 1000+10
#define INF 0x3f3f3f
using namespace std;
int arr[M][M];
bool vis[M];
int n, m;
void Init()
{
int a, b, x;
for(int i = ; i < n; i++)
for(int j = ; j < n; j++)
arr[i][j] = INF;
for(int i = ; i < n; i++)
arr[i][i] = ;
for(int i = ; i < m; i++)
{
scanf("%d%d%d", &a, &b, &x);
if(x < arr[a][b])
arr[a][b] = arr[b][a] = x;
}
}
void Dijkstra(int src)
{
int tmp, k;
memset(vis, , sizeof(vis));
vis[src] = ;
arr[][] = ;
for(int i = ; i < n; i++)
{
tmp = INF;
for(int j = ; j < n; j++)
{
if(arr[src][j] < tmp && !vis[j])
{
tmp = arr[src][j];
k = j;
}
}
vis[k] = ; //把找到的那个点标记为永久
for(int j = ; j < n; j++)
{
if(arr[src][k]+arr[k][j] < arr[src][j])
arr[src][j] = arr[src][k] + arr[k][j];
}
}
}
int main()
{
int s, t;
//freopen("input.txt", "r", stdin);
while(~scanf("%d%d", &n, &m))
{
Init();
scanf("%d%d", &s, &t);
Dijkstra(s);
if(arr[s][t] != INF)
printf("%d\n", arr[s][t]);
else
printf("-1\n");
}
return ;
}
畅通工程续(Dijkstra算法)的更多相关文章
- ACM: HDU 1874 畅通工程续-Dijkstra算法
HDU 1874 畅通工程续 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Desc ...
- HDU 1874 畅通工程续-- Dijkstra算法详解 单源点最短路问题
参考 此题Dijkstra算法,一次AC.这个算法时间复杂度O(n2)附上该算法的演示图(来自维基百科): 附上: 迪科斯彻算法分解(优酷) problem link -> HDU 1874 ...
- hdu 1874 畅通工程续 Dijkstra
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 题目分析:输入起点和终点,顶点的个数,已连通的边. 输出起点到终点的最短路径,若不存在,输出-1 ...
- 畅通工程续 (dijkstra)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- hdu 1874 畅通工程续 (dijkstra(不能用于负环))
畅通工程续Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- hdu1874畅通工程续 (dijkstra)
Problem Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行 ...
- hdu 1874 畅通工程续(求最短距离,dijkstra,floyd)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1874 /************************************************* ...
- 畅通工程续——E
E. 畅通工程续 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行走的距离要短很多.这让 ...
- hdoj 1874 畅通工程续【dijkstra算法or spfa算法】
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
随机推荐
- .net 和java JSON 模板
1..net 中JSON对象格式模板 // JSON键值对格式:'key':'value' public static string FORMAT_KEYVALUE = "\" ...
- HTML5 实现图像模糊算法
做个广告,WEB/PHP/JQ/HTML5/MYSQL/QQ群6848027 项目中需要用到HTML5模糊图像,以前用GDI,GDI+中都有现成的组件来实现,HTML5中如何实现? createIma ...
- 利用console控制台调试php代码
/** * 控制台输出 * @param $var * @param string $level */ public function console($var,$level = 'debug') { ...
- 射频识别技术漫谈(25)——Felica简介
Felica是SONY公司开发的射频识别技术,该技术使用的载波频率与ISO14443A和ISO14443B一样,都是13.56MHz,所以有人把它称为ISO14443C,但SONY并没有正式接受这样的 ...
- python使用easygui写图形界面程序
我 们首先下载一个类库easygui,它是一个Python用于简单开发图形化界面的类库,打开easygui的下载网页 http://sourceforge.net/projects/easygui/? ...
- opencv-python 学习笔记2:实现目光跟随(又叫人脸跟随)
如果机器人的脸能随着前方人脸而转动,你会不会觉得这种互动很有意思.年前的时候,学习了一下opencv,通过opencv可以简单的实现人脸跟随.再加上几个舵机控制头部转动,机器人就可以互动了.呵呵 这里 ...
- .net c# 提交包含文件file 的form表单 获得文件的Stream流
1.前台html代码 要写一个有id的form,可是不能有runat="server"属性.由于一个页面中,有这个属性的form表单仅仅能有一个. 再要有一个有name的ifram ...
- 偶然碰到的Win7 64位下CHM 的问题解决
最近下了几个沪江资料,都是chm格式的,但是在win7 64位下,都显示不了里面的音频和视频flash之类的控件,虽然可以通过源文件的方式打开视频文件,但是很麻烦. 网上似乎碰到的人也不是很多, ...
- 解决外贸电商难题,PayPal中国外贸电商大会圆满礼成
在全球经济一体化的背景下,越来越多的中国企业将目光转移到了海外.对中国的企业而言,要想将生意做到海外大致有两种方法可供选择,一是到海外设立分支机构或者分公司,二是通过外贸电子商务平台实现交易. ...
- hdu2964-Prime Bases
http://acm.hdu.edu.cn/showproblem.php?pid=2964 题意,给你一个整数n,现在要你分解成 n = k1 * ( 2 * 3 * ....*x1 ) + k2 ...