dijkstra算法类型题解

dijkstra算法(有权图,无权图):

带权路径长度------当图是带权图时,一条路径上所有边的权值之和,称为该路径的带权路径长度

初始化三个数组,final标记各顶点是否已找到最短路径,dist最短路径长度,path路径上的前驱

不断循环更新最短路径长度

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
const int INF = 1000000;
int main() {
	int n, g[205][205];
	cin >> n;
	for (int i = 1; i <= n; i++) 
		for (int j = 1; j <= n; j++) {
			if (i == j)g[i][j] = 0;
			else g[i][j] = INF;
		}
	
	for (int i = 1; i <= n - 1; i++) {
		for (int j = i + 1; j <= n; j++) {
			cin >> g[i][j];
	    }
	}
	int dis[205], book[205];
	memset(book, 0, sizeof(book));          
	for (int i = 1; i <= n; i++)
		dis[i] = g[1][i];
	dis[1] = 0;
	book[1] = 1;
	for (int i = 2; i <= n; i++) {
		int minn= INF, u;
		for (int j = 1; j <= n; j++) {
			if (!book[j] && dis[j] < minn) {
				minn= dis[j];
				u = j;
			}
		}
		book[u] = 1;
		for (int j = 1; j <= n; j++) {
			dis[j] = min(dis[j], dis[u] + g[u][j]);
		}
	}
	cout << dis[n];
	return 0;
}

第一个循环创数组,默认所有点之间的距离为无穷大(用一个大整型来表示),第二个循环输入数据,记录每个点之间的实际距离,dis是从一个点到其他点的距离数组,book是用来记录这个点是否被到达过的数组,后面的循环就是每次从一个点出发,找到与其距离最短的点并记录,同时更新到达其他点的距离

相关推荐
xin007hoyo2 小时前
算法笔记.染色法判断二分图
数据结构·笔记·算法
এ᭄画画的北北4 小时前
力扣-234.回文链表
算法·leetcode·链表
八股文领域大手子5 小时前
深入理解缓存淘汰策略:LRU 与 LFU 算法详解及 Java 实现
java·数据库·算法·缓存·mybatis·哈希算法
__lost5 小时前
C++ 解决一个简单的图论问题 —— 最小生成树(以 Prim 算法为例)
算法·图论·最小生成树·prim算法
wuqingshun3141596 小时前
蓝桥杯 11. 打印大X
数据结构·算法·职场和发展·蓝桥杯·深度优先
Blossom.1187 小时前
量子网络:构建未来通信的超高速“高速公路”
网络·opencv·算法·安全·机器学习·密码学·量子计算
A林玖7 小时前
【机器学习】朴素贝叶斯
人工智能·算法·机器学习
六边形战士DONK7 小时前
神经网络基础[损失函数,bp算法,梯度下降算法 ]
人工智能·神经网络·算法
wuqingshun3141598 小时前
蓝桥杯 2. 确定字符串是否是另一个的排列
数据结构·c++·算法·职场和发展·蓝桥杯
小刘|8 小时前
JVM 自动内存管理
java·jvm·算法