朴素版dijkstra算法

dijkstra算法用来处理无负权边的图,是单源最短路的算法

对于自环,因为是非负权边,所以不用考虑,不会走的

对于重边,在加入数组时,应仅加入最小的那条边

朴素版dijkstra算法一般用在稠密图,时间复杂度是O(n^2 + m),稠密图也就是边数m ~ 点数n^2级别的图

复制代码
#pragma optimize(2)
#include<bits/stdc++.h>
#include<unordered_map>
#define endl '\n'
#define int int64_t
using namespace std;
const int  N = 1e4 + 10;
struct edge { int v, w; };
vector<edge>e[N];
int d[N],vis[N],m,n,s;
void dijkstra(int s) {
    for (int i = 0; i <= n; ++i) d[i] = INT_MAX;
    d[s] = 0;
    for (int i = 0; i < n; ++i) {
         int u = 0;
         for (int j = 1; j <= n; ++j) 
             if (!vis[j] && d[u] > d[j]) u = j;
         vis[u] = 1;//出圈
         for (auto k : e[u]) {
             int v = k.v, w = k.w;
             d[v] = min(d[v], d[u] + w);
         }
    }
}
signed main() {
    ios::sync_with_stdio(false), cin.tie(0), cout.tie(0);
    cin >> n >> m >> s;
    for (int i = 1; i <= m; ++i) {
         int a, b, c; cin >> a >> b >> c;
         e[a].push_back({ b,c });
    }
    dijkstra(s);
    for (int i = 1; i <= n; ++i) cout << d[i] << " ";
    return 0;
}
相关推荐
智驱力人工智能21 分钟前
工厂智慧设备检测:多模态算法提升工业安全阈值
人工智能·算法·安全·边缘计算·智慧工厂·智能巡航·工厂设备检测
2501_924731473 小时前
城市路口识别准确率↑31%!陌讯时空建模算法在交通拥堵识别中的突破
人工智能·算法·目标检测·计算机视觉·目标跟踪
熬了夜的程序员3 小时前
【华为机试】208. 实现 Trie (前缀树)
数据结构·算法·华为od·华为
小O的算法实验室5 小时前
2024年ESWA SCI1区TOP,自适应种群分配和变异选择差分进化算法iDE-APAMS,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
不吃洋葱.6 小时前
左子树之和
算法
金融小师妹7 小时前
基于AI量化模型的比特币周期重构:传统四年规律是否被算法因子打破?
大数据·人工智能·算法
数据智能老司机8 小时前
图算法趣味学——最短路径
数据结构·算法·云计算
快去睡觉~8 小时前
力扣109:有序链表转换二叉搜索树
算法·leetcode·链表
是Dream呀8 小时前
YOLOv8深度解析:从架构革新到应用实践
人工智能·算法