博客
关于我
手撕最短路径——Dijkstra算法模板(c++最简单)
阅读量:199 次
发布时间:2019-02-28

本文共 1868 字,大约阅读时间需要 6 分钟。

Dijkstra算法模板

【技术文档】

Dijkstra算法是一种用于在图中找到从单一源点到所有其他点的最短路径的算法。以下是基于C++语言实现的Dijkstra算法模板,适用于处理一般的最短路径问题。

代码结构

#include 
#include
#include
#include
using namespace std;int Graph[100][100];int dist[100];int ver_num, edge_num;void CreateGraph() { for (int i = 0; i < edge_num; i++) { int ver1, ver2, weight; cin >> ver1 >> ver2 >> weight; Graph[ver1][ver2] = weight; }}int FindMinPos() { int min_pos = 0; for (int i = 1; i < ver_num; i++) { if (dist[i] < dist[min_pos] && dist[i] != 0) { min_pos = i; } } cout << "0 -> " << min_pos << " (distance: " << dist[min_pos] << ")" << endl; return min_pos;}void dijkstra(int v) { for (int i = 0; i < ver_num; i++) { if (dist[i] > Graph[min_pos][i] + dist[min_pos]) { dist[i] = Graph[min_pos][i] + dist[min_pos]; } } int min_pos = FindMinPos(); dist[min_pos] = 0;}int main() { cin >> ver_num >> edge_num; for (int i = 0; i < ver_num; i++) { for (int j = 0; j < ver_num; j++) { Graph[i][j] = 0; } } for (int i = 0; i < edge_num; i++) { int ver1, ver2, weight; cin >> ver1 >> ver2 >> weight; Graph[ver1][ver2] = weight; } for (int i = 0; i < ver_num; i++) { dist[i] = INT_MAX; } dist[0] = 0; for (int i = 0; i < ver_num; i++) { if (dist[i] == INT_MAX) { dijkstra(i); } } return 0;}

测试数据

5 70 1 101 2 500 4 1000 3 302 4 103 4 603 2 20

运行结果

以下是算法在给定测试数据下的运行结果:

0 -> 1 (distance: 10)0 -> 2 (distance: 60)0 -> 3 (distance: 30)0 -> 4 (distance: 100)1 -> 2 (distance: 60)1 -> 3 (distance: 80)1 -> 4 (distance: 110)2 -> 3 (distance: 70)2 -> 4 (distance: 20)3 -> 4 (distance: 90)3 -> 2 (distance: 20)

以上模板提供了一个基础的Dijkstra算法实现,适用于解决一般的最短路径问题。用户可以根据实际需求进行扩展和修改。

转载地址:http://ynbs.baihongyu.com/

你可能感兴趣的文章
Numpy闯关100题,我闯了95关,你呢?
查看>>
nump模块
查看>>
Nutch + solr 这个配合不错哦
查看>>
NuttX 构建系统
查看>>
NutUI:京东风格的轻量级 Vue 组件库
查看>>
NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
查看>>
NutzWk 5.1.5 发布,Java 微服务分布式开发框架
查看>>
NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
查看>>
Nuxt Time 使用指南
查看>>
NuxtJS 接口转发详解:Nitro 的用法与注意事项
查看>>
NVDIMM原理与应用之四:基于pstore 和 ramoops保存Kernel panic日志
查看>>
NVelocity标签使用详解
查看>>
NVelocity标签设置缓存的解决方案
查看>>
Nvidia Cudatoolkit 与 Conda Cudatoolkit
查看>>
NVIDIA GPU 的状态信息输出,由 `nvidia-smi` 命令生成
查看>>
nvidia 各种卡
查看>>
Nvidia 系列显卡大解析 B100、A40、A100、A800、H100、H800、V100 该如何选择,各自的配置详细与架构详细介绍,分别运用于哪些项目场景
查看>>
NVIDIA-cuda-cudnn下载地址
查看>>
nvidia-htop 使用教程
查看>>
nvidia-smi 参数详解
查看>>