图论最短路径算法——Dijkstra
说实在的,这算法很简单,很简单,很简单……因为它是贪心的,而且码量也小,常数比起SPFA也小。
主要思想
先初始化,dis[起点]=0,其它皆为无限大。
还要有一个bz数组,bz[i]表示i是否确定为最短路径
for i=1 to n
{
在未确定最短路径的点中找出u使dis[u]最小
bz[u]=1;
更新与u相连的所有点
}
就这么简单。
实现讲解
其实也很好实现。可以用邻接表储存,也可以用邻接矩阵储存,虽然会慢一点。因为Dijkstra算法本就是对付稠密图的,不过我还是建议用邻接表,见SPFA实现讲解
注意事项
Dijkstra不能处理负边权的状况,所以要看清题目大意才用它哦!
具体代码
#include <iostream>
#include <algorithm>
#include <string.h>
#include <math.h>
#include <limits.h>
using namespace std;
struct _Way//定义_Way类型,表示某点到点y的距离为len
{
int y,len;
};
int n,m;
int q;
_Way way[1001][1001] {};//way[i][j]表示从i开始的第j条路
_Way* bz[1001][1001] {};//读入时标记,防止重边出现。bz[i][j]指向从i到j的直接路径
int now[1001] {};//now[i]表示从i开始的边的数量
int dis[1001] {};//dis[i]表示从起点到i的最短路径
int min(int a,int b){return a<b?a:b;}
void Dijkstra(int);
int main()
{
ios::sync_with_stdio(false);
cin>>n>>m;
for(int i=1;i<=m;i++)
{
int x,y,len;
cin>>x>>y>>len;
if (bz[x][y]!=NULL)//若重边则替换之
{
bz[x][y]->len=min(bz[x][y]->len,len);
continue;
}
now[x]++;
way[x][now[x]].y=y;
way[x][now[x]].len=len;
bz[x][y]=&(way[x][now[x]]);//标记好地址
}
cin>>q;
Dijkstra(q);
for(int i=1;i<=n;i++)
{
if (dis[i]!=INT_MAX)
cout<<dis[i]<<endl;
else
cout<<"-1"<<endl;
}
return 0;
}
void Dijkstra(int q)//注意Dijkstra算法不能有负边权
{
bool bz[1001] {};//bz[i]表示点i是否已标记成最短路径
for(int i=0;i<=n;i++)
dis[i]=INT_MAX;
dis[q]=0;//初始化
for(int i=1;i<=n;i++)
{
int u {};
for(int j=1;j<=n;j++)
if ((!bz[j])&&(dis[j]<dis[u]))
u=j;//u为未确定点中dis最小的点
if (u==0) break;
bz[u]=1;//标记为确定点
for(int i=1;i<=now[u];i++)
dis[way[u][i].y]=min(dis[way[u][i].y],dis[u]+way[u][i].len);//更新与其相连的所有点
}
}
优化
用堆优化,暂时不会。
SPFA和Dijkstra哪个强?
SPFA擅长于稀疏图,而Dijkstra擅长于稠密图
SPFA可以处理负边权,Dijkstra不可以处理负边权
SPFA时间复杂度为O(kE),Dijkstra时间复杂度为O(n^2)
SPFA的空间要比Dijkstra多一个队列
SPFA的优化有SLF和LLL,Dijkstra的优化有堆优化
SPFA和Dijkstra均不可以处理负权回路
SPFA的时间系数要比Dijkstra大(Floyed和Ford笑了)
SPFA和Dijkstra都是单源的(Floyed又笑了)
没有边的图 O(1)特殊判断 SPFA秒过,完全图Dijkstra秒过(Floyed和Ford骄傲地说:“我们的时间是固定的!”)
图论最短路径算法——Dijkstra的更多相关文章
- 最短路径算法-Dijkstra算法的应用之单词转换(词梯问题)(转)
一,问题描述 在英文单词表中,有一些单词非常相似,它们可以通过只变换一个字符而得到另一个单词.比如:hive-->five:wine-->line:line-->nine:nine- ...
- 有向有权图的最短路径算法--Dijkstra算法
Dijkstra算法 1.定义概览 Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.Di ...
- 最短路径算法Dijkstra和A*
在设计基于地图的游戏,特别是isometric斜45度视角游戏时,几乎必须要用到最短路径算法.Dijkstra算法是寻找当前最优路径(距离原点最近),如果遇到更短的路径,则修改路径(边松弛). Ast ...
- 图论最短路径算法总结(Bellman-Ford + SPFA + DAGSP + Dijkstra + Floyd-Warshall)
这里感谢百度文库,百度百科,维基百科,还有算法导论的作者以及他的小伙伴们...... 最短路是现实生活中很常见的一个问题,之前练习了很多BFS的题目,BFS可以暴力解决很多最短路的问题,但是他有一定的 ...
- 图论-最短路径 2.Dijkstra算法O (N2)
2.Dijkstra算法O (N2) 用来计算从一个点到其他所有点的最短路径的算法,是一种单源最短路径算法.也就是说,只能计算起点只有一个的情况. Dijkstra的时间复杂度是O (N2),它不能处 ...
- 带权图的最短路径算法(Dijkstra)实现
一,介绍 本文实现带权图的最短路径算法.给定图中一个顶点,求解该顶点到图中所有其他顶点的最短路径 以及 最短路径的长度.在决定写这篇文章之前,在网上找了很多关于Dijkstra算法实现,但大部分是不带 ...
- 最短路径算法——Dijkstra,Bellman-Ford,Floyd-Warshall,Johnson
根据DSqiu的blog整理出来 :http://dsqiu.iteye.com/blog/1689163 PS:模板是自己写的,如有错误欢迎指出~ 本文内容框架: §1 Dijkstra算法 §2 ...
- 最短路径算法——Dijkstra算法
在路由选择算法中都要用到求最短路径算法.最出名的求最短路径算法有两个,即Bellman-Ford算法和Dijkstra算法.这两种算法的思路不同,但得出的结果是相同的. 下面只介绍Dijkstra算法 ...
- 最短路径算法——Dijkstra算法与Floyd算法
转自:https://www.cnblogs.com/smile233/p/8303673.html 最短路径 ①在非网图中,最短路径是指两顶点之间经历的边数最少的路径. AE:1 ADE:2 ...
随机推荐
- PMP项目管理——项目范围管理-规划范围管理
规划范围管理是为记录如何定义.确认和控制项目范围及产品范围,而创建范围管理计划的过程.主要作用是,在整个项目期间对如何管理范围提供指南和方向.制定范围管理计划和细化项目范围始于对下列信息的分析:项目章 ...
- ionic-CSS:ionic icon(图标)
ylbtech-ionic-CSS:ionic icon(图标) 1.返回顶部 1. ionic icon(图标) ionic 也默认提供了许多的图标,大概有 700 多个,针对 Android 和 ...
- sql中desc的妙用
很多情况下对表内部结构不熟悉,想看下我创建的表里面又多少表明,又想他按照首字母的规律排列, 这时候就要用desc +表名了. desc t_bike_info; hive> desc t_bik ...
- ps-奇幻金鱼彩妆
1.打开背景图,拷贝一份防止出错 2增加色相饱和度 改变全局的饱和度.这是 为了改变嘴唇的颜色.其他变色的地方可以通过添加蒙版,然后用背景色为黑色的画笔擦掉 3给眼睛上加上金鱼 置入图片 类型选 ...
- USACO2012 Broken necklace /// DP oj10103
题目大意: 项链最长的纯色连续段,“w”即white白色珠子,可任意涂为红或蓝,“r” “b”即红 蓝. Input Line 1: N, the number of beads Line 2: ...
- LightOJ 1151 Snakes and Ladders 期望dp+高斯消元
题目传送门 题目大意:10*10的地图,不过可以直接看成1*100的,从1出发,要到达100,每次走的步数用一个大小为6的骰子决定.地图上有很多个通道 A可以直接到B,不过A和B大小不确定 而且 ...
- Leetcode207. Course Schedule课程表
现在你总共有 n 门课需要选,记为 0 到 n-1. 在选修某些课程之前需要一些先修课程. 例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们: [0,1] 给定课程总量以及它 ...
- Java 巴什博弈(取石子报数问题)
巴什博弈:有一堆n个物品,两个人轮流从这堆物品中取物,规定每次至少取一个,最多取m个.最后取光者得胜. 规律:如果n=m+1,那么由于一次最多只能取m个,所以,无论先取者拿走多少个,后取者都能够一 ...
- 阿里云启动视频云V5计划,全面赋能生态合作伙伴
9月25 - 27日,主题为数·智的2019云栖大会在杭州举行.在第三天的智能视频云专场中,阿里云研究员金戈首次对外发布视频云V5计划,释放视频IT基础设施红利,赋能生态合作伙伴,共促大视频产业发展. ...
- docker中国区镜像加速
[root@syzyy ~]# vim /etc/docker/daemon.json { "registry-mirros":[ "https://registry.d ...