当前位置: 首页 > news >正文

深入解析:P4779 【模板】单源最短路径(标准版)

P4779 【模板】单源最短路径(标准版)

题目背景

2018 年 7 月 19 日,某位同学在 NOI Day 1 T1 归程 一题里非常熟练地使用了一个广为人知的算法求最短路。

然后呢?

100→60100 \rightarrow 6010060

Ag→Cu\text{Ag} \rightarrow \text{Cu}AgCu

最终,他因此没能与理想的大学达成契约。

小 F 衷心祝愿大家不再重蹈覆辙。

题目描述

给定一个 nnn 个点,mmm 条有向边的带非负权图,请你计算从 sss 出发,到每个点的距离。

数据保证你能从 sss 出发到任意点。

输入格式

第一行为三个正整数 n,m,sn, m, sn,m,s
第二行起 mmm 行,每行三个非负整数 ui,vi,wiu_i, v_i, w_iui,vi,wi,表示从 uiu_iuiviv_ivi 有一条权值为 wiw_iwi 的有向边。

输出格式

输出一行 nnn 个空格分隔的非负整数,表示 sss 到每个点的距离。

输入输出样例 #1

输入 #1

4 6 1
1 2 2
2 3 2
2 4 1
1 3 5
3 4 3
1 4 4

输出 #1

0 2 4 3

说明/提示

样例解释请参考 数据随机的模板题。

1≤n≤1051 \leq n \leq 10^51n105

1≤m≤2×1051 \leq m \leq 2\times 10^51m2×105

s=1s = 1s=1

1≤ui,vi≤n1 \leq u_i, v_i\leq n1ui,vin

0≤wi≤1090 \leq w_i \leq 10 ^ 90wi109,

0≤∑wi≤1090 \leq \sum w_i \leq 10 ^ 90wi109

本题数据可能会持续更新,但不会重测,望周知。

2018.09.04 数据更新 from @zzq

solution

Dijkstra 算法由荷兰计算机科学家 E. W. Dijkstra 于 1956 年发现,1959 年公开发表。是一种求解非负权图上单源最短路径的算法。

算法步骤:

记源点为 s,s 到任意点 u 的距离记为 d[u], 将已经确定最短路的点加入集合。
1 令 d[s] = 0,其它点为 d[i] = ∞
2 每次取不在 S 中的 d 最小的点 i 加入到 S,并用它松弛其它点,即
d[j] = min(d[j], d[i] + wij)
3 重复 2 直到所有点都属于 S

本题满足单源、非负权的条件,用该算法是效率比较高的算法,用堆优化的话最多可以实现 O(nlogn + m)。本文使用常用用堆优化 + lazy 操作,复杂度为O(mlogn)

代码

#include <iostream>#include "bit"#include "vector"#include "unordered_set"#include "unordered_map"#include "set"#include "queue"#include "algorithm"#include "bitset"#include "cstring"#include "cmath"using namespace std;typedef long long ll;const int N = 1e5 + 5, inf = 1e9 + 1;int n, m, s, vis[N];int d[N];vector<pair<int, int>> e[N];struct node {int u, dis;bool operator<(const node &y) const {return dis > y.dis;}};priority_queue<node> q;void dijkstra() {fill(d + 1, d + n + 1, inf);d[s] = 0;q.push({s, 0});while (!q.empty()) {auto [u, dis] = q.top();q.pop();if (vis[u]) continue;vis[u] = true;for (auto [v, w]: e[u]) {if (d[v] > d[u] + w) {d[v] = d[u] + w;q.push({v, d[u] + w});}}}}int main() {cin >> n >> m >> s;for (int i = 0, x, y, w; i < m; i++) {cin >> x >> y >> w;e[x].emplace_back(y, w);}dijkstra();for (int i = 1; i <= n; i++) cout << d[i] <<' ';return 0;}

结果

在这里插入图片描述

http://www.rkmt.cn/news/12180.html

相关文章:

  • [更新完毕]2025华为杯B题数学建模研赛B题研究生数学建模思路代码文章成品:无线通信系统链路速率建模 - 指南
  • redis-bitMap类型基本命令
  • 基于SpringBoot及PostgreSQL的国家减肥食谱管理项目(上):区域与省份安装搭建
  • 基于BP神经网络的激光焊接数据预测
  • Pandawiki:企业知识管理的全能管家
  • 鹿鼎记豪侠传:Rust 重塑 iOS 江湖(下) - 指南
  • 树的重心(邻接表)
  • 语音芯片怎样接? 语音芯片有哪些常见接口类型?
  • 详细介绍:2025华为杯A题B题C题D题E题F题选题建议思路数学建模研研究生数学建模思路代码文章成品
  • AtCoder Beginner Contest 424
  • ======================================分割线======================================
  • OpenLayers地图交互 -- 章节六:范围交互详解 - 实践
  • 游戏在高负载场景下,整机功耗控制在多少
  • 打印机状态错误,怎么恢复正常打印?
  • 牛客刷题-Day5
  • VonaJS多租户同时支持共享模式和独立模式
  • 实用指南:【C语言】统计二进制中1的个数:三种方法的比较与分析
  • vite-vue3 项目优化首屏加载速度
  • 深入解析:小九源码-springboot050-基于spring boot的苏蔚家校互联管理系统
  • 各种软件的官方文档和安装包下载地址记录
  • 基于导频的OFDM系统的信道估计(使用LS估计算法)
  • 快递100
  • python+springboot+uniapp微信小代码“美好食荐”框架 美食推荐 菜谱展示 用户互动 评论收藏框架
  • 领嵌iLeadE-588网关AI边缘计算盒子一键部署二次开发
  • 深入解析:PyTorch 神经网络工具箱核心内容
  • 【英语启蒙动画合集】0基础宝宝必看的动画,超全!直接下载~
  • AI 自动化智能体训练营 | 借助人工智能提升工作效率,打造自己的智能体工作流
  • 「Java EE开发指南」用MyEclipse开发的EJB开发工具(一)
  • MX-X21
  • 深入解析:博客SEO优化实战:从Google到百度,一套可复制的排名增长SOP