朴素版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;
}
相关推荐
亲爱的非洲野猪16 小时前
动态规划进阶:多维DP深度解析
算法·动态规划
AlenTech17 小时前
197. 上升的温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
橘颂TA17 小时前
【Linux 网络】TCP 拥塞控制与异常处理:从原理到实践的深度剖析
linux·运维·网络·tcp/ip·算法·职场和发展·结构与算法
tobias.b18 小时前
408真题解析-2010-9-数据结构-折半查找的比较次数
java·数据结构·算法·计算机考研·408真题解析
源代码•宸18 小时前
Leetcode—404. 左叶子之和【简单】
经验分享·后端·算法·leetcode·职场和发展·golang·dfs
WBluuue18 小时前
数据结构与算法:dp优化——优化尝试和状态设计
c++·算法·leetcode·动态规划
im_AMBER18 小时前
Leetcode 105 K 个一组翻转链表
数据结构·学习·算法·leetcode·链表
sin_hielo18 小时前
leetcode 1877
数据结构·算法·leetcode
睡不醒的kun19 小时前
定长滑动窗口-基础篇(2)
数据结构·c++·算法·leetcode·职场和发展·滑动窗口·定长滑动窗口
庄小焱19 小时前
【机器学习】——房屋销售价格预测实战
人工智能·算法·机器学习·预测模型