代码:

#include<iostream>
#include<vector>
#include<cstdio>
#include<queue>
#include<map>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<set>
#include<cstring>
using namespace std;
typedef long long ll;
const ll INF=;
const int MM=;
const int NM=;
int n,m,s;//点,边,起始
int dis[NM];//最小距离
bool book[NM];//记录有没有作为顶点搜索过
//链式向前星
struct NODE{
int to;
int nxt;
int c;
}node[MM];//链式向前星
int head[NM],lcnt=;
void add(int a,int b,int c){
node[lcnt].to=b;
node[lcnt].c=c;
node[lcnt].nxt=head[a];
head[a]=lcnt++;
}
int main()
{
ios_base::sync_with_stdio(false);
cin.tie();
cin>>n>>m>>s;
for(int i=;i<=n;i++){
dis[i]=INF;
}
for(int i=;i<m;i++){
int a,b,c;
cin>>a>>b>>c;
//if(a==b)
// continue; add(a,b,c);
//add(b,a,c);
}
for(int i=head[s];i;i=node[i].nxt){ //从起始点开始枚举
int idx=node[i].to;
dis[idx]=min(node[i].c,dis[idx]); //更新最短路 }
dis[s]=; //自身距离为0
book[s]=; //标记搜索过
for(int kkk=;kkk<n;kkk++){ //枚举每个点(用编号)
int minn=INF,u=;
for(int i=;i<=n;i++){
if(!book[i]&&dis[i]<minn){
u=i; //枚举每个已经被标记了但是没有被搜索过的点
minn=dis[i]; //找距离最小的
}
} /*for(int i=1;i<=n;i++){
if(mp[u][i]<INF){
dis[i]=min(dis[i],dis[u]+mp[u][i]);
}
}*/ for(int i=head[u];i;i=node[i].nxt){
int idx=node[i].to; //正在搜索的点开始,枚举每一条边 dis[idx]=min(dis[idx],dis[u]+node[i].c); //更新最短距离,设f[i][j]为i到j的最大距离,d[i]为起始点到i的距离
//得到 d[j]=min(d[j],d[i]+f[i][j])
} book[u]=; //标记这个点搜索过了 }
for(int i=;i<=n;i++){
cout<<dis[i]<<" ";
}
return ;
}

查看神奇代码

1.储存方式:

链式向前星>> https://www.cnblogs.com/dudujerry/p/9915713.html

int n,m,s;//点,边,起始
int dis[NM];//最小距离
bool book[NM];//记录有没有作为顶点搜索过
//链式向前星
struct NODE{
int to;
int nxt;
int c;
}node[MM];//链式向前星
int head[NM],lcnt=1;
void add(int a,int b,int c){
node[lcnt].to=b;
node[lcnt].c=c;
node[lcnt].nxt=head[a];
head[a]=lcnt++;
}

  

2.更新所有与根节点连接的最短路

for(int i=head[s];i;i=node[i].nxt){             //枚举所有与起点连接的边
int idx=node[i].to;
     dis[idx]=min(node[i].c,dis[idx]); //更新最短路 }
dis[s]=0; //自身距离为0
book[s]=1; //标记搜索过

使用book记录是否作为过用来更新的点, 则搜完之后 book[s]=1

3.接下来枚举除源点外所有点来作为用来更新最短路的点

依 ”从上次求出最短路的点中选出最短路最小的点“ 的顺序遍历除源点以外的n-1个点

for(int kkk=1;kkk<n;kkk++){          //枚举n-1次,因为原点已经被用来更新过了
int minn=INF,u=0;
for(int i=1;i<=n;i++){
if(!book[i]&&dis[i]<minn){ //枚举每个已经被标记了但是没有被搜索过的点
u=i;
minn=dis[i]; //找距离最小的
}
}
. . .

4.从选出的点开始更新所有与它连接的边

设已知 源点到i点的距离dis[i] 和 点i到点j的距离f[i][j]    (未知当前dis [ j ]是否正确)

可以得到  dis [ j ] = min ( dis [ j ] , dis [ i ] + f [ i ] [ j ] )

根据上面的方程可以遍历所有与选出的点,算出最短路

         . . .
          for(int i=head[u];i;i=node[i].nxt){
int idx=node[i].to; //正在搜索的点开始,枚举每一条边 dis[idx]=min(dis[idx],dis[u]+node[i].c); //更新最短距离,设f[i][j]为i到j的最大距离,d[i]为起始点到i的距离
//得到 d[j]=min(d[j],d[i]+f[i][j])
} book[u]=1; //标记这个点搜索过了 }

  

5.输出

dis [ i ]就是源点到i点的距离

for(int i=1;i<=n;i++){
cout<<dis[i]<<" ";
}

  

【最短路算法】Dijkstra知识点&代码的更多相关文章

  1. (转)最短路算法--Dijkstra算法

    转自:http://blog.51cto.com/ahalei/1387799         上周我们介绍了神奇的只有五行的Floyd最短路算法,它可以方便的求得任意两点的最短路径,这称为“多源最短 ...

  2. 最短路算法 Dijkstra 入门

    dijkstra算法 是一种单源点最短路算法求出一个点到其他所有点的最短路. 给你这样的一个图,需要求出1号点到其他点的最短距离是多少. 首先我们开一个数组 d[N],d[x] 代表着从起点出发到x点 ...

  3. 10行实现最短路算法——Dijkstra

    今天是算法数据结构专题的第34篇文章,我们来继续聊聊最短路算法. 在上一篇文章当中我们讲解了bellman-ford算法和spfa算法,其中spfa算法是我个人比较常用的算法,比赛当中几乎没有用过其他 ...

  4. 图的最短路算法 Dijkstra及其优化

    单源最短路径算法 时间复杂度O(N2) 优化后时间复杂度为O(MlogN)(M为图中的边数 所以对于稀疏图来说优化后更快) 不支持有负权的图 #include<iostream> usin ...

  5. 最短路算法 —— Dijkstra算法

    用途: 解决单源最短路径问题(已固定一个起点,求它到其他所有点的最短路问题) 算法核心(广搜): (1)确定的与起点相邻的点的最短距离,再根据已确定最短距离的点更新其他与之相邻的点的最短距离. (2) ...

  6. Dijkstra最短路算法

    Dijkstra最短路算法 --转自啊哈磊[坐在马桶上看算法]算法7:Dijkstra最短路算法 上节我们介绍了神奇的只有五行的Floyd最短路算法,它可以方便的求得任意两点的最短路径,这称为“多源最 ...

  7. 【啊哈!算法】算法7:Dijkstra最短路算法

    上周我们介绍了神奇的只有五行的Floyd最短路算法,它可以方便的求得任意两点的最短路径,这称为“多源最短路”.本周来来介绍指定一个点(源点)到其余各个顶点的最短路径,也叫做“单源最短路径”.例如求下图 ...

  8. 【最短路算法】Dijkstra+heap和SPFA的区别

    单源最短路问题(SSSP)常用的算法有Dijkstra,Bellman-Ford,这两个算法进行优化,就有了Dijkstra+heap.SPFA(Shortest Path Faster Algori ...

  9. 【坐在马桶上看算法】算法7:Dijkstra最短路算法

           上周我们介绍了神奇的只有五行的Floyd最短路算法,它可以方便的求得任意两点的最短路径,这称为“多源最短路”.本周来来介绍指定一个点(源点)到其余各个顶点的最短路径,也叫做“单源最短路径 ...

随机推荐

  1. iOS CoreData 开发

    新年新气象,曾经的妹子结婚了,而光棍的我决定书写博客~ 废话结束. 本人不爱使用第三方的东东,喜欢原汁原味的官方版本,本次带来CoreData数据存储篇~ 创建应用

  2. jQuery——属相操作

    属性获取:attr(属性名), 属性设置:attr(属性名,具体值) 移除属性:removeAttr(属性名) 特殊情况:prop(属性名).prop(属性名,具体值):表单中状态属性checked. ...

  3. [Windows Server 2012] Apache+PHP安全设置

    ★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com ★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频. ★ 本节我们将带领大家:Win20 ...

  4. 离线安装Selenium

    https://blog.csdn.net/poem_ruru/article/details/79032140

  5. Nagios事件机制实践

    Nagios事件机制实践  blog地址:http://www.cnblogs.com/caoguo 一.事件触发执行脚本 [root@Nagios ~]# cd /usr/local/nagios/ ...

  6. Cesium学习笔记(九):导入3D模型(obj转gltf)

    在用cesium的过程中难免需要导入别人做好的3D模型,这时候就需要将这些模型转成gltf格式了 当然,官方也给了我们一个网页版的转换器,但是毕竟是网页版的,效率极其低下,文件还不能太大,所以我们就需 ...

  7. 用C#在Visual Studio写Javascript单元测试

    1.在vs创建一个标准的单元测试工程 2.引用nuget包:Edge.js 我是用的是6.11.2版本 3.编写JsRunner类 using EdgeJs; using System; using ...

  8. JS弹出子窗口

    目的 在一个主窗口中,点击一个链接, 弹出一个子窗口 , 父窗口保留 在子窗口中点击关闭, 关闭子窗口. 子窗口的位置位于屏幕的中间 实现 main.html <!DOCTYPE html> ...

  9. 初学者怎么快速掌握Linux运维?

    2018年里,Linux运维的职位数量和平均薪资水平仍然持续了去年的强劲增幅,比很多开发岗位涨的都快.从研究机构的数据来看,Linux职位数量和工资水平涨幅均在IT行业的前五之列,比去年的表现还要好一 ...

  10. c3p0 连接池配置

    C3P0 可使用properties 配置文件方式,将c3p0.properties放在classpath目录下,如果为WEB应用,放在WEB-INF\classes下 c3p0.properties ...