【图论】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;
} 
相关推荐
仰泳的熊猫几秒前
1149 Dangerous Goods Packaging
数据结构·c++·算法·pat考试
_OP_CHEN7 分钟前
【算法基础篇】(三十七)图论基础之多源最短路:Floyd 算法吃透所有点对最短路径!
算法·蓝桥杯·图论·算法竞赛·floyd算法·acm/icpc·多源最短路
Web极客码7 分钟前
如何选择最适合的内容管理系统(CMS)?
java·数据库·算法
程序员三明治14 分钟前
【动态规划】01背包与完全背包问题详解,LeetCode零钱兑换II秒解,轻松解力扣
算法·leetcode·动态规划·java后端·01背包·完全背包·零钱兑换
自由生长202415 分钟前
大数据计算框架-流式计算的Join
算法
IT猿手16 分钟前
融合DWA的青蒿素优化算法(Artemisinin Optimization Algorithm, AOA)求解无人机三维动态避障路径规划,MATLAB代码
算法·matlab·无人机
H_z___18 分钟前
Codeforces Global Round 31 (Div. 1 + Div. 2) A ~ E
数据结构·算法
小龙报21 分钟前
【算法通关指南:算法基础篇 】双指针专题:1.唯一的雪花 2.逛画展 3.字符串 4.丢手绢
c语言·数据结构·c++·人工智能·深度学习·算法·信息与通信
superman超哥9 小时前
仓颉语言中基本数据类型的深度剖析与工程实践
c语言·开发语言·python·算法·仓颉
Learner__Q9 小时前
每天五分钟:滑动窗口-LeetCode高频题解析_day3
python·算法·leetcode