dijkstra算法类型题解

news/2025/2/9 7:51:04 标签: 算法

dijkstra算法(有权图,无权图):
带权路径长度——当图是带权图时,一条路径上所有边的权值之和,称为该路径的带权路径长度

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

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

 

#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是用来记录这个点是否被到达过的数组,后面的循环就是每次从一个点出发,找到与其距离最短的点并记录,同时更新到达其他点的距离


http://www.niftyadmin.cn/n/5845796.html

相关文章

Axios 的原理

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

域名无法注册怎么办?

无论是个人博客、企业官网还是在线商店&#xff0c;域名都是我们在互联网世界中的“名片”。然而&#xff0c;很多人在注册域名时常常会遇到各种各样的问题&#xff0c;尤其是“域名无法注册”这一情况。那么&#xff0c;当你发现自己心仪的域名无法注册时&#xff0c;该怎么办…

自然语言处理NLP_[1]-NLP入门

文章目录 1.自然语言处理入门1. 什么是自然语言处理2.自然语言处理的发展简史3 自然语言处理的应用场景1. **机器翻译**2. **文本分类**3. **情感分析**4. **问答系统**5. **文本生成**6. **信息抽取**7. **语音识别与合成**8. **文本摘要**9. **搜索引擎优化**10. **聊天机器人…

Maven 与企业项目的集成

1. Maven 在企业级项目中的作用 Maven 是 Java 生态中最流行的构建和依赖管理工具&#xff0c;广泛用于企业级项目的构建、依赖管理、测试、打包、部署和 CI/CD 集成。对于大型企业项目&#xff0c;Maven 提供了一整套标准化的构建流程&#xff0c;并支持 多模块&#xff08;M…

【AIGC】冷启动数据与多阶段训练在 DeepSeek 中的作用

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: AIGC | ChatGPT 文章目录 &#x1f4af;前言&#x1f4af;冷启动数据的作用冷启动数据设计 &#x1f4af;多阶段训练的作用阶段 1&#xff1a;冷启动微调阶段 2&#xff1a;推理导向强化学习&#xff08;RL&#xff0…

使用 Docker 和 PM2 构建高并发 Node.js API 网关

在现代 Web 开发中&#xff0c;构建高并发、高可用的 API 网关是一个常见的需求。本文将介绍如何结合 Docker 和 PM2 构建一个高性能的 Node.js API 网关&#xff0c;并深入探讨分布式限流器的原理与实现。 1. 背景与需求 1.1 高并发 API 网关的挑战 在高并发场景下&#xff…

Kafka中的KRaft算法

我们之前的Kafka值依赖于Zookeeper注册中心来启动的&#xff0c;往里面注册我们节点信息 Kafka是什么时候不依赖Zookeeper节点了 在Kafka2.8.0开始就可以不依赖Zookeeper了 可以用KRaft模式代替Zookeeper管理Kafka集群 KRaft Controller和KRaft Leader的关系 两者关系 Lea…

驱动开发系列34 - Linux Graphics Intel 动态显存技术的实现

一:概述 动态显存技术(Dynamic Video Memory Technology, DVMT)是一种由 Intel 提出的内存分配技术,主要用于整合显卡(集成显卡)系统中,以便动态地调整显存大小,从而在不同的负载场景下优化内存使用和系统性能。 动态显存技术的核心在于共享系统内存。集成显卡没有独立…