朴素版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;
}
相关推荐
懒羊羊不懒@18 分钟前
Java基础语法—最小单位、及注释
java·c语言·开发语言·数据结构·学习·算法
白云千载尽2 小时前
leetcode 912.排序数组
算法·leetcode·职场和发展
哆啦刘小洋2 小时前
Tips:预封装约束的状态定义
算法
代码充电宝2 小时前
LeetCode 算法题【简单】290. 单词规律
java·算法·leetcode·职场和发展·哈希表
Juan_20122 小时前
P1040题解
c++·算法·动态规划·题解
Onesoft%J1ao2 小时前
C++竞赛递推算法-斐波那契数列常见题型与例题详解
c++·算法·动态规划·递推·信息学奥赛
以己之3 小时前
NC313 两个数组的交集
算法·哈希算法
Brookty3 小时前
【算法】前缀和
java·学习·算法·前缀和·动态规划
And_Ii3 小时前
LeetCode 3397. 执行操作后不同元素的最大数量
数据结构·算法·leetcode
额呃呃3 小时前
leetCode第33题
数据结构·算法·leetcode