把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

相关内容

热门资讯

一分钟辅助!hhpoker有后... 一分钟辅助!hhpoker有后台操作吗,wepoker辅助器有哪些功能,绝活儿教程(今日头条)1、玩...
5分钟辅助!wepoker透视... 5分钟辅助!wepoker透视挂底牌,wpk安卓下载辅助,诀窍教程(有挂辅助)1、wepoker透视...
第1分钟辅助!wepoker辅... 第1分钟辅助!wepoker辅助器安装包,佛手大菠萝辅助,机巧教程(有挂分享)1、每一步都需要思考,...
第七分钟辅助!wepoker好... 第七分钟辅助!wepoker好友助力码,德普之星辅助器app,积累教程(有挂猫腻)1、德普之星辅助器...
第7分钟辅助!wepoker私... 第7分钟辅助!wepoker私人局辅助器怎么用,约局吧开挂神器是真的吗,模板教程(的确有挂)进入游戏...
3分钟辅助!poker wor... 3分钟辅助!poker world辅助器,竞技联盟透视插件,要领教程(有挂详细)1、首先打开竞技联盟...
第一分钟辅助!pokemmo手... 第一分钟辅助!pokemmo手机脚本辅助器,aa poker辅助,手段教程(的确有挂)运pokemm...
1分钟辅助!wepoker钻石... 1分钟辅助!wepoker钻石怎么看底牌,hhpoker脚本下载,教材教程(有挂解惑)1、上手简单,...
第4分钟辅助!约局吧app有挂... 第4分钟辅助!约局吧app有挂吗,hhpoker作弊码怎么用,方案教程(有挂方针)1、首先打开hhp...
第5分钟辅助!德普之星怎么设置... 第5分钟辅助!德普之星怎么设置埋牌,拱趴大菠萝万能挂图解,积累教程(有挂工具)1、许多玩家不知道德普...