图论——最短路径

news/2024/12/23 5:44:20/

目录

  • Dijkstra 算法
  • Floyd-Warshall's algorithm
  • 用动态规划求解问题
  • 项目计划

Dijkstra 算法

Dijkstra’s algorithm(迪杰斯特拉算法)是一种用于解决图中单源最短路径问题的贪婪算法。该算法由荷兰计算机科学家Edsger Dijkstra于1956年提出。它主要用于计算从一个起始顶点到图中所有其他顶点的最短路径。

算法步骤如下:

初始化: 创建一个集合S,用于存储已找到最短路径的顶点,以及一个数组dist,用于存储从起始顶点到各个顶点的最短路径长度。将起始顶点的距离设置为0,其他顶点的距离设置为无穷大。将所有顶点标记为未访问。

找到最短路径: 从未访问的顶点中选择距离起始顶点最近的顶点,将其标记为已访问,并更新与该顶点相邻的顶点的最短路径距离。更新的规则是如果通过当前选定的顶点可以得到更短的路径,就更新距离数组dist。

重复: 重复步骤2,直到所有顶点都被访问。在每次迭代中,都选择未访问的顶点中距离起始顶点最近的顶点。

最终结果: 一旦所有顶点都被访问,dist数组中存储的值就是从起始顶点到每个顶点的最短路径长度。

Dijkstra算法的关键优势是它可以在非负权重的有向图中


http://www.ppmy.cn/news/1338646.html

相关文章

spring cache的使用(Redis)

要在Spring Boot应用中使用Redis作为缓存,你需要遵循一些步骤来配置和使用Redis。以下是使用Spring Cache抽象与Redis进行整合的详细说明: 1. 添加依赖 首先,需要在pom.xml中添加Spring Boot的Redis starter依赖以及缓存的starter依赖。这会…

【Python】requests库的介绍及用法

目录 1、应用场景 2、requests-三方库 1、应用场景 Python中的requests库被广泛应用在需要发送HTTP请求的场景中。以下列举了一些主要的应用场景: API调用: 许多服务提供了API接口,我们可以使用requests库发送GET、POST、PUT、DELETE等请…

vue3使用is动态切换组件报错Vue received a Component which was made a reactive object.

vue3使用is动态切换组件,activeComponent用ref定义报错 Vue received a Component which was made a reactive object. This can lead to unnecessary performance overhead, and should be avoided by marking the component with markRaw or using shallowRef ins…

【云原生】docker安全与https加密的超文本传输协议CA证书生成

目录 一、docker安全 二、http与https的区别 三、为什么要使用 SSL 证书? 四、https证书认证的过程 https单向认证的访问流程 https双向认证的访问流程 五、如何获取证书? 六、实操获取证书并验证 1、通过阿里云获取证书 2、通过mkcert获取证书…

C++基础语法学习笔记

C Tutorial 1.基础语法 C 应用&#xff1a;操作系统、图形用户界面和嵌入式系统 C和C区别&#xff1a;C支持类和对象 C语法 #include <iostream> using namespace std;int main(){cout << "hello world!";return 0; }int main () { cout << &q…

Java 对部分接口返回数据进行加密,或其他处理

业务场景&#xff1a;后端项目中分为PC端和移动端接口&#xff0c;移动端为例如 mobile 开头的URl&#xff0c;需求为调用移动端接口时&#xff0c;对返回数据进行加密&#xff0c;PC端不加密 import cn.hutool.core.date.DatePattern; import cn.hutool.json.JSONConfig; impo…

postgresql 查询缓慢原因分析

pg_stat_activity 最近发现系统运行缓慢&#xff0c;查询数据老是超时&#xff0c;于是排查下pg_stat_activity 系统表&#xff0c;看看有没有耗时的查询sql SELECT pid, state, query, query_start, backend_type FROM pg_stat_activity WHERE state active AND query LIK…

华为mate60 pro与小米14 pro 的巅峰对决

今天我们换下思路&#xff0c;不讲技术了&#xff01;我们一起讲讲手机&#xff01;小编暂时充当一下业余的数码咖。 今天我们就讲讲华为mate60 pro和小米14pro 这两款手机。这两款手机都是近期新出的发行版本&#xff0c;热度那是一直未减啊。 华为mate60 Pro 我们先说说这个…