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

本文共 1937 字,大约阅读时间需要 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 7
0 1 10
1 2 50
0 4 100
0 3 30
2 4 10
3 4 60
3 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/

你可能感兴趣的文章
Node响应中文时解决乱码问题
查看>>
node基础(二)_模块以及处理乱码问题
查看>>
node安装卸载linux,Linux运维知识之linux 卸载安装node npm
查看>>
node安装及配置之windows版
查看>>
Node实现小爬虫
查看>>
Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
查看>>
Node提示:npm does not support Node.js v12.16.3
查看>>
Node搭建静态资源服务器时后缀名与响应头映射关系的Json文件
查看>>
Node服务在断开SSH后停止运行解决方案(创建守护进程)
查看>>
node模块化
查看>>
node模块的本质
查看>>
node环境下使用import引入外部文件出错
查看>>
node环境:Error listen EADDRINUSE :::3000
查看>>
Node的Web应用框架Express的简介与搭建HelloWorld
查看>>
Node第一天
查看>>
node编译程序内存溢出
查看>>
Node读取并输出txt文件内容
查看>>
node防xss攻击插件
查看>>
noi 1996 登山
查看>>
noi 7827 质数的和与积
查看>>