迪杰斯特拉算法(C++)

目录

 

介绍:

代码: 

结果:

介绍:

迪杰斯特拉算法(Dijkstra's algorithm)是一种用于计算加权图的单点最短路径的算法。它是由荷兰计算机科学家Edsger W. Dijkstra在1956年发明的。

该算法的思路是,从给定源点开始,不断找到距离该点最近的未访问节点,标记这个节点为已访问,并更新与该节点相邻的节点的最短路径。通过这样不断扩大已访问节点的范围,最终可以求出源点到其他所有节点的最短路径。

具体实现时,可以使用一个优先队列来保存即将访问的节点,优先队列中的元素按照节点与源点的距离从小到大排序,每次取出距离最小的节点进行访问。

迪杰斯特拉算法的复杂度为O(E log V),其中E为边的数量,V为节点的数量。虽然该算法是一个贪心算法,并不能保证一定找到最优解,但对于大多数实际应用场景而言,其效率和正确性都已经得到了充分的验证。

 

代码: 

#include<iostream>
using namespace std;
int G[100][100], n, maxint=999, min1, v;
int s[100],d[100],path[100];//集合s代表已经找到最短路径的点
void DIJ(int v0)//迪杰斯特拉算法,从v0点到任意点的最短路径
{for (int i = 0; i < n; i++)//初始化{s[i] = 0;//视为空集d[i] = G[v0][i];//初始最短路径为v0到个点的权值if (d[i] < maxint)//v0与i之间有弧,则前驱设为v0path[i] = v0;else//v0与i之间无弧,则前驱设为-1path[i] = -1;}s[v0] = 1;//将v0加入集合sd[v0] = 0;//源点到源点距离为0for (int i = 1; i < n; i++)//访问剩下的n-1个点{min1 = maxint;for (int j = 0; j < n; j++){if (!s[j] && d[j] < min1)//点不在集合s内且小于最小边{v = j;//选择一条当前最短路径,终点为vmin1 = d[j];}}s[v] = 1;//将v加入集合sfor (int j = 0; j < n; j++)//将v加入集合后,更新从v0到剩余点的最短路{if (!s[j] && (d[v] + G[v][j]) < d[j])//该点不在集合s内且加入v点后最短路径小于之前的最短路径{d[j] = d[v] + G[v][j];//更新最短路径path[j] = v;//前驱设为v}}}for (int i = 1; i < n; i++)//访问各点的最短路径{int t = path[i];cout << i << "点的最短路径:"<<i<<" ";while (t != -1){cout << t << " ";t = path[t];}cout << "最短路径长度"<<d[i];cout << endl;}
}
int main()
{cout << "输入顶点数:" << endl;cin >> n;for (int i = 0; i < n; i++)for (int j = 0; j < n; j++)G[i][j] = maxint;cout << "输入边数:" << endl;int e;cin >> e;cout << "输入边:" << endl;for (int i = 1; i <= e; i++){int v1, v2, w;cin >> v1 >> v2 >> w;G[v1][v2] = w;}DIJ(0);//从0号点到任意点的最短路径
}

结果:

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

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

相关文章

合成事件在san.js中的应用

一、 什么是合成事件 DOM3 Event 新增了合成事件(CompositionEvent ), 用于处理通常使用 IME 输入时的复杂输入序列。 二、合成事件常见事件 compositionstart&#xff1a;文本合成系统如 IME&#xff08;即输入法编辑器&#xff09;开始新的输入合成时会触发 compositionst…

SUID提权教程

SUID提权方法 一、SUID是什么&#xff1f;二、如何设置SUID权限&#xff1f;三、已知的具有SUID权限的二进制可执行文件四、查找具有root权限的SUID的文件1.find命令提权2.nmap命令提权3.more命令提权4.less命令提权5.bash命令提权6.vim命令提权7.awk命令提权8.cp命令提权 五、…

springcloudalibaba-3

一、Nacos Config入门 1. 搭建nacos环境【使用现有的nacos环境即可】 使用之前的即可 2. 在微服务中引入nacos的依赖 <!-- nacos配置依赖 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-…

【动态规划】求解编辑距离问题

目录 问题描述递推关系运行实例时空复杂度优化Hirschberg 算法 问题描述 编辑距离问题是求解将⼀个字符串转换为另⼀个字符串所需的插⼊、删除、替换的最小次数。 C O M M O M → s u b C O M M U M → s u b C O M M U N → i n s C O M M U N E \mathbb{COMMOM} \overset{sub…

HarmonyOS真机调试报错:INSTALL_PARSE_FAILED_USESDK_ERROR处理

1、 新建应用时选择与自己真机匹配的sdk版本 查看自己设备sdk版本 创建时先择匹配版本&#xff1a; 2、 根据报错提示连接打开处理方案 3、查询真机版本对应的compileSdkVersion 和 compatibleSdkVersion 提示3.1版本之后和3.1版本之前的不同命令&#xff08;此处为3.0版…

Scrum框架中的Sprint

上图就是sprint里要做的事。Sprint是scrum框架的核心&#xff0c;是所有的想法、主意转换为价值的地方。所有实现产品目标的必要工作都在sprint里完成&#xff0c;这些工作主要包括Sprint 计划&#xff08;Sprint planning&#xff09;、每日站会&#xff08;Daily Scrum&#…

异地工业设备集中运维、数据采集,一招搞定

为了提升运维效率&#xff0c;能够及时发现和响应设备的故障、异常和潜在问题。 越来越多的企业都在搭建“集中式”的远程智慧运维体系&#xff0c;以提高运维效率和降低成本。 异地工业设备远程运维&#xff0c;提升响应效率、降低运维成本 以国内陕西某机床公司为例&#xff…

vue+element实现多级表头加树结构

标题两种展示方式 方式一 完整代码: <template><div class"box"><el-tableref"areaPointTable":data"tableData"border:span-method"objectSpanMethod":header-cell-style"tableHeaderMerge"><el-ta…

【10套模拟】【6】

关键字&#xff1a; 有向图入度、无向图度、一次深度优先、快速排序平均性能、折半查找、判断是否是二叉排序树、链式直接入插入排序

现在的各类解释非常混乱,到底什么是智慧城市?

智慧城市&#xff0c;简单来说&#xff0c;就是运用先进的信息和通信技术&#xff0c;让城市管理更加智能、高效&#xff0c;让市民的生活更加便捷、舒适。 在我们日常生活中&#xff0c;智慧城市带来的改变无处不在。 想象一下&#xff0c;当你早上醒来&#xff0c;你的手机已…

腾讯云新用户优惠活动有哪些可以参加?腾讯云新人服务器优惠活动

腾讯云作为国内领先的云服务提供商&#xff0c;不仅为用户提供稳定可靠的云服务器&#xff0c;还为新用户带来了一系列的优惠活动和代金券&#xff0c;以降低购买成本&#xff0c;提高业务效益。在这里&#xff0c;我们将为您详细介绍腾讯云服务器的新人优惠活动及代金券&#…

vue3+vant 实现树状多选组件

vue3vant 实现树状多选组件 需求描述效果图代码父组件引用selectTree组件 tree组件数据格式 需求描述 移动端需要复刻Pc端如上图的功能组件&#xff0c;但vant无组件可用&#xff0c;所以自己封装一个。 效果图 代码 父组件引用 import TreeSelect from "/selectTree.vu…