【数据结构】最短路径

在图论中,最短路径问题是一个经典且重要的问题,它用于寻找两个顶点之间距离最短的路径。本文将详细介绍两种常用的最短路径算法——Dijkstra算法和Bellman-Ford算法的原理,并提供C语言代码示例,演示它们的实现方式及应用场景。

一、Dijkstra算法

Dijkstra算法是一种贪心算法,用于求解带有非负权值的加权图的单源最短路径问题。它的基本思想是,从起始顶点开始,逐步扩展已经找到的最短路径集合,直到找到从起始顶点到所有其他顶点的最短路径。

理论知识:

  1. 初始化: 将起始顶点到所有其他顶点的距离初始化为无穷大,起始顶点到自身的距离初始化为0。
  2. 迭代过程: 每次从尚未访问的顶点中选择距离最短的顶点,更新与其相邻的顶点的距离。
  3. 终止条件: 所有顶点都被访问完毕,或者所有顶点都已经加入到最短路径集合中。

C语言实现:

下面是用C语言实现Dijkstra算法的示例代码:

#include <stdio.h>
#include <limits.h>#define V 5 // 图中顶点数int minDistance(int dist[], int sptSet[]) {int min = INT_MAX, min_index;for (int v = 0; v < V; v++) {if (sptSet[v] == 0 && dist[v] < min) {min = dist[v];min_index = v;}}return min_index;
}void printSolution(int dist[]) {printf("顶点到源点的最短路径距离:\n");for (int i = 0; i < V; i++) {printf("%d -> %d\n", i, dist[i]);}
}void dijkstra(int graph[V][V], int src) {int dist[V];int sptSet[V];for (int i = 0; i < V; i++) {dist[i] = INT_MAX;sptSet[i] = 0;}dist[src] = 0;for (int count = 0; count < V - 1; count++) {int u = minDistance(dist, sptSet);sptSet[u] = 1;for (int v = 0; v < V; v++) {if (!sptSet[v] && graph[u][v] && dist[u] != INT_MAX && dist[u] + graph[u][v] < dist[v]) {dist[v] = dist[u] + graph[u][v];}}}printSolution(dist);
}int main() {int graph[V][V] = {{0, 4, 0, 0, 0},{4, 0, 8, 0, 0},{0, 8, 0, 7, 0},{0, 0, 7, 0, 9},{0, 0, 0, 9, 0}};dijkstra(graph, 0);return 0;
}

二、Bellman-Ford算法

Bellman-Ford算法是一种用于求解带有负权值的加权图的单源最短路径问题的动态规划算法。它的基本思想是,从源顶点开始,逐步扩展已经找到的最短路径集合,直到找到从源顶点到所有其他顶点的最短路径。

理论知识:

  1. 初始化: 将源顶点到所有其他顶点的距离初始化为无穷大,源顶点到自身的距离初始化为0。
  2. 迭代过程: 进行 V-1 次松弛操作,即尝试通过中间顶点更新顶点间的距离。

检测负权环: 再进行一次松弛操作,如果仍然可以更新距离,则图中存在负权环。

C语言实现:

下面是用C语言实现Bellman-Ford算法的示例代码:

#include <stdio.h>
#include <stdlib.h>
#include <limits.h>#define V 5 // 图中顶点数
#define E 8 // 图中边数typedef struct {int src, dest, weight;
} Edge;void printSolution(int dist[]) {printf("顶点到源点的最短路径距离:\n");for (int i = 0; i < V; i++) {printf("%d -> %d\n", i, dist[i]);}
}void bellmanFord(Edge edges[], int src) {int dist[V];for (int i = 0; i < V; i++) {dist[i] = INT_MAX;}dist[src] = 0;for (int i = 0; i < V - 1; i++) {for (int j = 0; j < E; j++) {int u = edges[j].src;int v = edges[j].dest;int weight = edges[j].weight;if (dist[u] != INT_MAX && dist[u] + weight < dist[v]) {dist[v] = dist[u] + weight;}}}for (int i = 0; i < E; i++) {int u = edges[i].src;int v = edges[i].dest;int weight = edges[i].weight;if (dist[u] != INT_MAX && dist[u] + weight < dist[v]) {printf("图中存在负权环\n");return;}}printSolution(dist);
}int main() {Edge edges[E] = {{0, 1, -1}, {0, 2, 4}, {1, 2, 3}, {1, 3, 2},{1, 4, 2}, {3, 2, 5}, {3, 1, 1}, {4, 3, -3}};bellmanFord(edges, 0);return 0;
}

通过以上的理论介绍和C语言代码示例,我们深入了解了Dijkstra算法和Bellman-Ford算法这两种常用的最短路径算法,并学习了它们的实现方式及应用场景。在实际应用中,根据具体情况选择合适的算法,将有助于解决各种图相关的最短路径问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/3969.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Hive,Presto,Spark 共性

Hive、Presto 和 Spark 都是大数据处理工具&#xff0c;都属于大数据处理技术栈&#xff0c;都需要集群环境支持&#xff0c;都可以进行数据处理和分析。 都可以进行数据处理&#xff1a;Hive、Presto、Spark 都可以用 SQL 语句进行数据处理&#xff0c;也可以用它们的语言&…

【算法模板】图论基础算法

文章目录 图论算法基础模板树与图的存储1. 邻接矩阵&#xff1a;2. 邻接表&#xff1a; 树与图的遍历(1)深度优先搜索 (DFS)深度优先遍历 (DFS)(2)宽度优先搜索 (BFS)宽度优先遍历 (BFS) 拓扑排序朴素Dijkstra算法堆优化版Dijkstra算法Bellman-Ford算法SPFA算法SPFA判断图中是否…

2024年4月计算机视觉论文推荐

本文将整理4月发表的计算机视觉的重要论文&#xff0c;重点介绍了计算机视觉领域的最新研究和进展&#xff0c;包括图像识别、视觉模型优化、生成对抗网络(gan)、图像分割、视频分析等各个子领域 扩散模型 1、Tango 2: Aligning Diffusion-based Text-to-Audio Generations th…

react的参数值和Vue的参数值有什么区别

React和Vue在参数值的处理上存在一些区别&#xff0c;这主要体现在它们的设计理念和语法上。 在Vue中&#xff0c;参数值主要涉及到组件的定义、使用和传递过程。Vue允许通过传递参数来向组件传递数据、事件和样式等信息&#xff0c;从而实现组件的复用和灵活性。Vue的参数通常…

Java上传文件并存储到MySQL数据库

Java上传文件并存储到MySQL数据库实现过程&#xff1a; 第一步创建接口层 /** *文件接口层 */RestControllerRequestMapping("/file")public class FileController { //引用文件业务层 Resource private FileService fileService; /** *上传文件接…

C语言:一维数组、二维数组、字符数组介绍

数组 介绍一维数组定义应用方法初始化 举例示例结果 二维数组定义应用方法初始化 举例示例结果 字符数组定义应用方法初始化 举例示例结果分析 介绍 在C语言中&#xff0c;数组是一种基本的数据结构&#xff0c;用于存储一系列相同类型的数据。数组可以是多维的&#xff0c;最…

Vscode上使用Clang,MSVC, MinGW, (Release, Debug)开发c++完全配置教程(包含常见错误),不断更新中.....

1.VSCode报错头文件找不到 clang(pp_file_not_found) 在Fallback Flags中添加 -I&#xff08;是-include的意思&#xff0c;链接你的编译器对应头文件地址&#xff0c;比如我下面的是MSVC的地址&#xff09; 问题得到解决~

2024-04-24 游戏开发-区块链游戏-记录

摘要: 2024-04-24 游戏开发-区块链游戏-记录 记录&#xff1a; Saku Monsters GamFi赛道举世瞩目 3A级大作——Illuvium - 知乎 (zhihu.com) 3A链游大作开启内测&#xff0c;详解Bigtime、Illuvium和Parallel的玩法和资产市值-元宇宙Web3.0官网 (jianggupiao.com) lluvium&…

【Elasticsearch<二>✈️✈️】基本属性概念与MySQL数据库的不同之处

目录 &#x1f378;前言 &#x1f37b;一、Elasticsearch 基本属性 1.1 ES VS MySQL 1.2 ES 属性概念 1.3 ES 的增删改查 &#x1f37a;二、自动补全场景 2.1 场景举例 2.2 使用数据分词器 2.3 查询的流程 2.4 整个查询流程图 &#x1f379;章末 &#x1f378;前言 上次初步…

C++进阶--智能指针

智能指针的概念 智能指针是C中的一个重要概念&#xff0c;用于管理动态分配的对象内存。它是一个类模板&#xff0c;通过封装原始指针&#xff0c;并在对象生命周期结束时自动释放内存&#xff0c;从而避免了内存泄漏和资源管理的繁琐工作。 C标准库提供了多种常见的智能指针…

CasinoRoyale靶机练习实践报告

CasinoRoyale靶机练习实践报告 下载地址: https://drive.google.com/open?id1FYP246L63zShV00wOckAQ5F5XJ4HkZ0Lhttps://download.vulnhub.com/casinoroyale/CasinoRoyale.ovahttps://download.vulnhub.com/casinoroyale/CasinoRoyale.ova.torrent ( Magnet) 1 安装靶机 …

【Java Spring MVC项目异常解决】HTTP 500

HTTP 500状态码表示“内部服务器错误”&#xff08;Internal Server Error&#xff09;。这是一个通用的错误响应&#xff0c;表明服务器在处理请求时遇到了预料之外的情况&#xff0c;导致无法完成请求。500错误是服务器端错误的一种&#xff0c;与客户端无关。在Web开发中&am…

强化SSH服务安全的最佳实践

SSH&#xff08;Secure Shell&#xff09;作为一种广泛应用于Linux和其他类Unix系统中的强大工具&#xff0c;为管理员提供了安全的远程登录和命令执行功能。在现今高度互联的网络环境中&#xff0c;确保SSH服务的安全性显得尤为重要。本文将详细阐述一系列SSH服务的最佳实践&a…

【LangChain系列 12】Prompt模版——序列化

本文速读&#xff1a; PromptTemplate FewShotPromptTemplate 通常prompt以文件形式存储比python代码更好&#xff0c;一方面可以更容易共享、存储。本文将介绍在LangChain中如何对prompt以不同的方式序列化。 一般来说&#xff0c;对于序列化有以下两个设计原则&#xff1a…

吴恩达机器学习笔记:第 8 周-13 聚类(Clustering)13.3-13.5

目录 第 8 周 13、 聚类(Clustering)13.3 优化目标13.4 随机初始化13.5 选择聚类数 第 8 周 13、 聚类(Clustering) 13.3 优化目标 K-均值最小化问题&#xff0c;是要最小化所有的数据点与其所关联的聚类中心点之间的距离之和&#xff0c;因此 K-均值的代价函数&#xff08;又…

《微信公众号开发---一站式开发流程完整版本》 测试公众号账号及本地环境搭建/验证本地编写的代码,接入微信指南请求测试正常

文章目录 目录 文章目录 安装流程 小结 概要安装流程技术细节小结 概要 1.准备工作 1.需要先登录微信公众号平台&#xff1a;微信公众平台 注册如果是公司开发请注册服务号&#xff0c;个人开发请注册订阅号 2.注册完成&#xff0c;需要开通认证 2.以上操作完成&#xff0c…

精选GenAI和LLM学习资源

1、概念介绍 a) Andrej Karpathy-大型语言模型简介&#xff1a; Intro to Large Language Models 该视频对 LLMs 进行了一般性和高级的介绍&#xff0c;涵盖推理、缩放、微调、安全问题和提示注入等主题。 b) 英伟达-生成式AI解释&#xff1a; Generative AI explained 该视…

Ubuntu: 自留小技巧

#!/bin/bash# 指定要检查的文件夹 folder"/path/to/your/directory"# 遍历文件夹中的每一个文件 for file in "$folder"/* do# 检查文件中的每一行是否都包含"#"if awk !/#/ "$file" | read -r _then# 如果有一行不包含"#"&…

通信原理(2)--随机过程

通信原理(2)–随机过程 3.1随机过程的基本概念 随机过程{x(t)}由一族时间函数 x i ( t ) x_i(t) xi​(t)&#xff0c;i1,2.3…组成&#xff0c;每一个时间函数 x i ( t ) x_i(t) xi​(t)称为随机过程{x(t)}的一个样本函数&#xff08;一个实现&#xff09; 每个样本函数在时间…

ASP.NET某企业信息管理系统的设计与实现

摘 要 信息管理系统就是我们常说的MIS(Management Information System),它是一个计算机软硬件资源以及数据库的人-机系统。经过对题目和内容的分析,选用了Microsoft公司的ASP.NET开发工具,由于它提供了用于从数据库中访问数据的强大工具集,使用它可以建立开发比较完善的数据库…