关于dijkstra求最短路(模板)
嗯....
dijkstra是求最短路的一种算法(废话,思维含量较低,
并且时间复杂度较为稳定,为O(n^2),
但是注意:!!!! 不能处理边权为负的情况(但SPFA可以处理,今后会讲)
借一个何大佬的图,因为会在代码中提到红、绿、空三种颜色,以及小v,
通过图会比较清晰一些:
思路大约明白了下面就呈上带批注模板代码:
#include <cstdio>//dijkstra求最短路 #include <cstring> #include <algorithm> using namespace std; ; int g[maxn][maxn], n, m;//g数组用来存图 int dis[maxn], status[maxn];//dis数组中存储的是从起点到第i个点的最短路长度 /*status//(状态)用来存点的类型,1.已经求出最短路的点(把它想成红色,用2来表示) 2.是从已经求出最短路的点向外延伸一次就可找到的点(把它想成绿色,用1来表示) 3.其余还没有访问的,仍没有色(用0来表示)*/ //注意每一种算法都要新开一个函数,使代码简单易懂 void dijkstra(int start_point) {//dijkstra 最短路写法: memset(dis, 0x3f, sizeof(dis));//将dis数组中的每一个元素都设为正无穷, //因为后面要用它与更小的最短路进行比较,所以它为最大,且定义为正无穷 dis[start_point] = ;//确定边界,起点的最短路一定为0 status[start_point] = ;//起点已求出最短路,首先标记为绿色,进行分析 ; ti < n; ++ti) //枚举n次 { ;//将小V初始化为-1(小V即为要找的点) ; i <= n; ++i) //再次进行枚举 { ) //如果i点为绿色 { || dis[i] < dis[vertex_to_pick]) //如果v还没有被更新或者说是找到一个点i比点v到出发点的距离更近,则也进行更新 { vertex_to_pick = i;//进行更新 } } } ) { break;//如果找不到下一个点,则退出 } status[vertex_to_pick] = ;//将已经更新好的最近的v添加到red集合 ; i <= n; ++i) //从找到的v点进行更新dis数组 { || status[i] == ) //如果i点还没有添加到red集合 { )// 并且满足从小v这个点到i点有距离 { status[i] = ;//再次将i点加入绿色集合,进行循环,找到所有相邻点 dis[i] = min(dis[i], dis[vertex_to_pick] + g[vertex_to_pick][i]);//更新i点的最短路 } } } } } int main() { //主函数进行输入、调用、输出 memset(g, -, sizeof(g)); scanf("%d%d", &n, &m); ; i < m; ++i) { int u, v, w; scanf("%d%d%d", &u, &v, &w); g[u][v] = g[v][u] = w; } dijkstra(); printf("%d",dis[n]); ; }
多背几遍应该能明白, 反正一直除了更新就是更新.....
关于dijkstra求最短路(模板)的更多相关文章
- ACM - 最短路 - AcWing 849 Dijkstra求最短路 I
AcWing 849 Dijkstra求最短路 I 题解 以此题为例介绍一下图论中的最短路算法.先让我们考虑以下问题: 给定一个 \(n\) 个点 \(m\) 条边的有向图(无向图),图中可能存在重边 ...
- Aizu-2249 Road Construction(dijkstra求最短路)
Aizu - 2249 题意:国王本来有一个铺路计划,后来发现太贵了,决定删除计划中的某些边,但是有2个原则,1:所有的城市必须能达到. 2:城市与首都(1号城市)之间的最小距离不能变大. 并且在这2 ...
- acwing 850. Dijkstra求最短路 II 模板
地址 https://www.acwing.com/problem/content/description/852/ 给定一个n个点m条边的有向图,图中可能存在重边和自环,所有边权均为非负值. 请你求 ...
- Dijkstra算法求最短路模板
Dijkstra算法适合求不包含负权路的最短路径,通过点增广.在稠密图中使用优化过的版本速度非常可观.本篇不介绍算法原理.只给出模板,这里给出三种模板,其中最实用的是加上了堆优化的版本 算法原理 or ...
- 850. Dijkstra求最短路 II(堆优化模板)
给定一个n个点m条边的有向图,图中可能存在重边和自环,所有边权均为非负值. 请你求出1号点到n号点的最短距离,如果无法从1号点走到n号点,则输出-1. 输入格式 第一行包含整数n和m. 接下来m行每行 ...
- 849. Dijkstra求最短路 I(模板)
给定一个n个点m条边的有向图,图中可能存在重边和自环,所有边权均为正值. 请你求出1号点到n号点的最短距离,如果无法从1号点走到n号点,则输出-1. 输入格式 第一行包含整数n和m. 接下来m行每行包 ...
- acwing 849 Dijkstra求最短路 I 模板
地址 https://www.acwing.com/problem/content/description/851/ 给定一个n个点m条边的有向图,图中可能存在重边和自环,所有边权均为正值. 请你求出 ...
- 850. Dijkstra求最短路 II
给定一个n个点m条边的有向图,图中可能存在重边和自环,所有边权均为正值. 请你求出1号点到n号点的最短距离,如果无法从1号点走到n号点,则输出-1. 输入格式 第一行包含整数n和m. 接下来m行每行包 ...
- 849. Dijkstra求最短路 I
给定一个n个点m条边的有向图,图中可能存在重边和自环,所有边权均为正值. 请你求出1号点到n号点的最短距离,如果无法从1号点走到n号点,则输出-1. 输入格式 第一行包含整数n和m. 接下来m行每行包 ...
随机推荐
- [原]NYOJ-开灯问题-77
大学生程序代写 //http://acm.nyist.net/JudgeOnline/problem.php?pid=77 /*题目77题目信息运行结果本题排行讨论区开灯问题 时间限制:3000 ms ...
- NOI2018网络同步赛游记
Day1 t1是一道NOI选手眼中的送分题,对于我来说还是有难度的,用了个把小时想了出来可持久化并查集的做法,最后一个点被卡常.赛后才发现Kruskal重构树是这样的简单.t2.t3由于我真的是太弱了 ...
- Nodejs文件相关操作
欢迎关注我的博客我在马路边 适用人群 本文适用于刚接触Node的小白,毕竟我也是小白,大佬请绕行. Node文件操作 在实际开发中遇到很多有关文件及文件夹的操作,比如创建.删除文件及文件夹,文件拷贝. ...
- 使用UIVisualEffectView创建毛玻璃效果
UIVisuaEffectView :继承自UIView,可以看成是专门用于处理毛玻璃效果的视图,只要我们将这个特殊的View添加到其他视图(eg. ImageView )上面,被该UIVisuaEf ...
- android开发之数据库存取图片
Android数据库中存取图片通常使用两种方式,一种是保存图片所在路径,二是将图片以二进制的形式存储(sqlite3支持BLOB数据类型).对于两种方法的使用,好像第二种方法不如第一种方法更受程序员欢 ...
- codeblocks如何支持_tmain?可移植代码的编码推荐
codeblocks默认源代码文件编码根据OS而定,编译时编码UTF-8. 在你不更改任何codeblocks配置时: 在WINDOWS中:源代码——WINDOW ...
- for循环中的条件执行循序
问题: public class Main { public static void main(String[] args) { int i,n,length = 0; for(i=1;length& ...
- puppet前端管理工具foreman-proxy bind 127.0.0.1:8443问题解决
最近在玩foreman,发现部署foreman-proxy的时候,总是出现8443bind在127.0.0.1端口,导致无法访问的情况. 如下图: 经过strace -o log.txt bin/sm ...
- ES6学习之Class
一.定义类(ES6的类,完全可以看做是构造函数的另一种写法) class Greet { constructor(x, y) { this.x = x; this.y = y; } sayHello( ...
- JavaScript原型模式(prototype)
1.原型是一个对象,其他对象可以通过它实现属性的继承所有对象在默认的情况下都有一个原型,因为原型的本身也是对象,所以一个类的真正原型是被类的内部[prototype]属性所指出.每个函数都有一个属性叫 ...