news 2026/5/26 19:54:13

图论天花板:Dijkstra最短路径算法详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
图论天花板:Dijkstra最短路径算法详解

一、上期回顾 Day30

掌握图论基础、邻接表、拓扑排序,解决任务依赖、有向图判环、课程排序问题。今天学习图论天花板级高频考点Dijkstra 单源最短路径算法


二、Dijkstra 算法核心概念

1. 解决什么问题

给定带权有向 / 无向图,求一个起点其他所有点最短路径

  • 权值:距离、时间、花费
  • 适用:边权非负(没有负数权值)

2. 核心思想(贪心)

  1. 每次选离起点最近未访问的点
  2. 用这个点松弛(更新)它邻居的距离
  3. 标记已访问,不再重复处理
  4. 直到所有点处理完毕

三、必备数据结构

  1. 邻接表:存图(比邻接矩阵高效)
    vector<pair<int, int>> edge[N]; // edge[u] = {v, w} 从u到v,边权w
  2. 距离数组 dist []dist[i]起点到 i 点的最短距离
  3. 访问数组 vis []:标记已确定最短路径的点
  4. 优先队列(堆):堆优化,O (E log V),效率爆炸

四、堆优化 Dijkstra 万能模板(必背)

#include <iostream> #include <vector> #include <queue> #include <climits> using namespace std; const int N = 10005; vector<pair<int, int>> edge[N]; // 邻接表:to, weight int dist[N]; // 最短距离 bool vis[N]; // 访问标记 int n, m; // 点数,边数 // Dijkstra 堆优化版 void dijkstra(int start) { // 初始化距离为无穷大 fill(dist, dist + N, INT_MAX); fill(vis, vis + N, false); dist[start] = 0; // 优先队列:小根堆(距离最小优先) // pair<int, int>:{距离,节点编号} priority_queue<pair<int, int>, vector<pair<int, int>>, greater<pair<int, int>>> pq; pq.push({0, start}); while (!pq.empty()) { auto [d, u] = pq.top(); pq.pop(); if (vis[u]) continue; // 已处理跳过 vis[u] = true; // 遍历所有邻居 for (auto [v, w] : edge[u]) { if (!vis[v] && dist[v] > d + w) { dist[v] = d + w; pq.push({dist[v], v}); } } } } int main() { cin >> n >> m; for (int i = 0; i < m; i++) { int u, v, w; cin >> u >> v >> w; edge[u].emplace_back(v, w); // 无向图再加一行 edge[v].emplace_back(u, w); } dijkstra(1); // 从1号点出发 // 输出到所有点的最短距离 for (int i = 1; i <= n; i++) cout << dist[i] << " "; return 0; }

五、关键步骤拆解

  1. 初始化:起点距离 = 0,其余无穷大
  2. 小根堆:每次拿最近点
  3. 松弛操作
    if (dist[v] > dist[u] + w) dist[v] = dist[u] + w;
  4. 标记访问:每个点只处理一次,保证效率

六、适用场景

  1. 地图导航最短路径
  2. 网络传输最小延迟
  3. 工程最小花费
  4. 带权图单源最短路(无负权

七、易错点提醒

  1. 必须用小根堆(greater),不能用默认大根堆
  2. 边权不能为负数,否则失效
  3. 无向图 = 双向加边
  4. 距离数组初始化为极大值

八、今日核心总结

  1. Dijkstra =贪心 + 堆优化 + 松弛操作
  2. 解决带权图单源最短路径
  3. 邻接表存图,小根堆提速
  4. 时间复杂度O(E log V),刷题首选
  5. 边权不能为负

九、课后练习

  1. 手写堆优化 Dijkstra 模板
  2. 构造简单带权图,求起点到各点最短路
  3. 尝试无向图写法
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 19:53:12

2026年好用的AI论文平台推荐

写论文的困扰&#xff0c;是无数学生和科研工作者难以言说的“心病”。从浩如烟海的文献中寻找灵感&#xff0c;到反复修改格式的繁琐操作&#xff0c;再到查重降重带来的无尽焦虑&#xff0c;每一个环节都像是学术道路上的“隐形绊脚石”。进入2026年&#xff0c;AI论文工具早…

作者头像 李华
网站建设 2026/5/26 19:50:36

2025-2026年微博广告推广推荐:TOP5评测价格专业案例注意事项适用场景

摘要 在数字化营销浪潮中&#xff0c;微博作为兼具社交属性与媒体爆发力的核心平台&#xff0c;已成为品牌实现高效曝光、精准触达与流量转化的战略要地。然而&#xff0c;面对日益复杂的平台算法、碎片化的用户注意力与不断攀升的获客成本&#xff0c;广告主在微博广告推广的选…

作者头像 李华
网站建设 2026/5/26 19:49:14

直销选哪家?伍福家园产品好

选择直销公司时&#xff0c;需要综合多方面因素考量&#xff0c;并没有绝对的“最佳”选择。不同直销公司各有特色&#xff0c;像安利、完美、无限极等都是知名度较高的企业。以下结合山药粉来深度拆解选择直销公司时需考虑的要点。产品质量与种类产品是直销的核心。以山药粉为…

作者头像 李华
网站建设 2026/5/26 19:48:16

零代码教培APP开发价格?

传统教培APP开发需要投入10-50 万元的定制开发费用&#xff0c;周期长达2-6 个月&#xff0c;且需组建专业技术团队维护。而零代码开发通过可视化拖拽、预封装组件和云原生架构&#xff0c;将开发门槛降至零基础&#xff0c;同时实现90% 成本节省和10 倍 开发效率提升。本文将…

作者头像 李华
网站建设 2026/5/26 19:47:37

博士生紧急必读:ChatGPT辅助写作的学术红线清单(教育部2024新规+12所双一流高校AI使用细则对比)

更多请点击&#xff1a; https://kaifayun.com 第一章&#xff1a;博士生AI写作合规性认知重构 博士阶段的学术写作正经历一场由生成式AI驱动的认知范式迁移。传统“作者—文本—引用”三位一体的学术诚信框架&#xff0c;正在遭遇LLM辅助创作、跨模态内容生成与实时协同编辑等…

作者头像 李华
网站建设 2026/5/26 19:43:18

亲测昆明热门美食商家,到底哪家更专业呢?

宝子们&#xff0c;在昆明想吃地道美食可太难了&#xff01;就拿东南亚菜来说&#xff0c;我之前踩过不少雷。要么是口味不正宗&#xff0c;东南亚风味“泰化”严重&#xff0c;老挝、越南、柬埔寨风味被模糊&#xff1b;要么是价格贵&#xff0c;分量还小&#xff0c;性价比极…

作者头像 李华