【图论】Dijkstra单源最短路径-朴素方法-简单模板(迪杰斯特拉算法)

Dijkstra单源最短路径

问题描述

输入n 表示n 个结点,m表示m 条边,求编号1的结点到每个点的最短路径

输出从第一个点到第n个点的最短路径

思路

  1. 将图g[][]中所有的权值初始化为0x3f表示正无穷

  2. dist[]中所有的值初始化为0x3f表示从第一个点到所有点的距离默认为无穷

  3. dist[1]设置为0表示从第一个点到它自己距离为

  4. 执行n(也就是处理n个点的次数)次如下操作:

    • 找到所有没有确定最短路径的点中,离1点(初始点)最近的那个

      例如: 下面这个图,第一次找到结点1,因为它没有被确定过最短路径, 然后更新到达2的路径为新的最短路为2 ,到达3 的最短路为4

c 复制代码
#include <iostream>
#include <cstring>
using namespace std;

const int N = 510;		
int g[N][N], dist[N];	//g为邻接矩阵 
bool st[N];	  			//表示结点是否已经确定最短路径 
int n, m;				//n为结点数量,m为边数量 

int Dijkstra() {
	memset(dist, 0x3f, sizeof dist);
	dist[1] = 0;		//从第一个结点到达第一个结点的最短路径为 0 
	for (int i = 0; i < n; i++ ) {	//循环 n 次处理 n 个结点 
		int t = -1;
		for (int j = 1; j <= n; j++ ) {
			if (!st[j] && (t == -1 || dist[j] < dist[t])) {	//第一次会选择找到的第一个边然后去找最短的边 
				t = j;	//寻找没有确定最短路径的点当中 到第一个点最近的点 
			}
		}
		//找到没有确定的最近的点
		for (int j = 1; j <= n; j++) {
			dist[j] = min(dist[j], dist[t] + g[t][j]);
		}//从第一个最近的点开始向后更新最短路径 
		st[t] = true;	//将确定好最短路径的点设置为true表示已经确定了最短路径 
	}
	return dist[n];
}

//测试数据:
/*
3 3
1 2 2
1 3 4
2 3 1
*/ 

int main() {
	ios::sync_with_stdio(false);
	cin.tie(0);
	cin >> n >> m; 
	memset(g, 0x3f, sizeof g);
	while (m -- ) {
		int u, v, c;
		cin >> u >> v >> c;
		g[u][v] = c;	//无重边的情况,如果有重边需要进行取重边的最小值 
	}
	int t = Dijkstra();
	cout << t << endl;
} 
相关推荐
05候补工程师1 分钟前
深度解构 ROS 2:如何手动调通 Nav2 A* 路径规划引擎
linux·人工智能·经验分享·算法·机器人
上弦月-编程21 分钟前
【C语言逻辑题】谋杀案凶手是谁?——经典矛盾推理题详解
算法
天若有情67332 分钟前
逆向玩家狂喜!用C++野生写法一键破解线性加密(不规范但巨好用)
开发语言·c++·算法
风筝在晴天搁浅1 小时前
剑指Offer 60.n个骰子的点数
算法
ProgramHelpOa1 小时前
Optiver 2026 OA 全面复盘|26NG / Intern 最新高频题型整理
人工智能·算法·机器学习
feifeigo1231 小时前
基于无迹变换的电网概率潮流分析 MATLAB 实现
开发语言·算法·matlab
Java成神之路-1 小时前
【算法刷题笔记】全题型导航目录
笔记·算法
爱写代码的倒霉蛋1 小时前
2022年天梯赛L1-8真题解析(哈希+排序)
数据结构·算法
Struggle_97551 小时前
算法知识-倍增算法
算法
计算机安禾1 小时前
【计算机网络】第5篇:网桥学习与生成树算法——环路拓扑中的路径收敛问题
学习·计算机网络·算法