把Djikstra算法改写为C++代码
创始人
2024-11-20 07:30:31
0

Djikstra算法是一种解决单源最短路径问题的算法,其基本思想是:维护一个集合S,记录已确定了最短路径的定点,以及一个数组dist,记录源点到其他点的最短路径长度。算法的流程如下:

  1. 初始化:将源点加入集合S,并将dist数组初始化为源点到其他点的距离。

  2. 重复执行以下步骤直到集合S包含所有顶点:

a. 找到距离集合S最近的顶点u,也就是dist[u]最小的顶点。

b. 将顶点u加入集合S。

c. 对集合V-S(即未被确定最短路径的点)中的每个顶点v,如果存在一条边(u, v),则更新v的最短路径:dist[v] = min(dist[v], dist[u] + wu,v),其中wu,v表示边(u, v)的权重。

最终,dist数组中存储的就是源点到其他顶点的最短路径长度。

下面是C++代码实现:

#include 
#include 
#include 
#include 

using namespace std;

const int N = 100010, INF = 0x3f3f3f3f;

int h[N], e[N], ne[N], w[N], idx;
int dist[N];
bool st[N];
int n, m;

void add(int a, int b, int c)
{
    e[idx] = b, w[idx] = c, ne[idx] = h[a], h[a] = idx ++ ;
}

void dijkstra()
{
    memset(dist, 0x3f, sizeof dist);
    dist[1] = 0;

    priority_queue, vector>, greater<>> pq;
    pq.push({0, 1});

    while (pq.size

相关内容

热门资讯

第七分钟辅助!aapoker破... 第七分钟辅助!aapoker破解侠是真的吗,We poker辅助器下载,法子教程(有挂秘籍)1、这是...
第十分钟辅助!pokemmo脚... 第十分钟辅助!pokemmo脚本辅助器下载,菠萝辅助器免费版的功能介绍,经验教程(有挂教程)1)菠萝...
7分钟辅助!wepoker透视... 7分钟辅助!wepoker透视有没有,wepoker轻量版透视,妙计教程(有挂功能)1、每一步都需要...
6分钟辅助!德普之星怎么开辅助... 6分钟辅助!德普之星怎么开辅助,wepoker脚本下载,项目教程(真实有挂)1、玩家可以在德普之星怎...
第五分钟辅助!aapoker怎... 第五分钟辅助!aapoker怎么设置提高好牌几率,如何下载wpk透视版,演示教程(有挂方针)1、aa...
第8分钟辅助!wpk安卓下载辅... 第8分钟辅助!wpk安卓下载辅助,哈糖大菠萝怎么挂,经验教程(有挂方法)哈糖大菠萝怎么挂破解侠是真的...
第三分钟辅助!hhpoker免... 第三分钟辅助!hhpoker免费辅助器,aapoker辅助软件合法吗,烘培教程(有挂神器)一、aap...
第二分钟辅助!wepoker插... 第二分钟辅助!wepoker插件功能辅助器,wepoker私人局透视插件,妙招教程(有挂细节)1、金...
六分钟辅助!wepoker透视... 六分钟辅助!wepoker透视是真的吗,wpk俱乐部辅助器,阶段教程(发现有挂)1、wepoker透...
第四分钟辅助!wepoker有... 第四分钟辅助!wepoker有没有透视方法,wepoker有机器人吗,妙计教程(有挂攻略)1、用户打...