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

news/2025/9/26 12:15:09/文章来源:https://www.cnblogs.com/yxysuanfa/p/19113243

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.mzph.cn/news/918231.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

US$36 35160WT Adapter for CG Pro 9S12 Programmer

35160WT Adapter for CG Pro 9S12 Programmer35160WT Adapter Features: For the 35160T chip design that cannot be erased, it can directly repair the original vehicle red dot and directly use the original c…

[更新完毕]2025华为杯B题数学建模研赛B题研究生数学建模思路代码文章成品:无线通信系统链路速率建模 - 指南

[更新完毕]2025华为杯B题数学建模研赛B题研究生数学建模思路代码文章成品:无线通信系统链路速率建模 - 指南2025-09-26 12:13 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: …

西安北郊网站开发wordpress 主题 企业

线程启动原理线程中断机制多线程实现方式FutureTask实现原理线程池之ThreadPoolExecutor概述线程池之ThreadPoolExecutor使用线程池之ThreadPoolExecutor状态控制线程池之ThreadPoolExecutor执行原理线程池之ScheduledThreadPoolExecutor概述线程池的优雅关闭实践 转载&#x…

适合大学生做的兼职网站有哪些网页一键建站

敏捷开发模式已经逐渐被主流的软件研发团队所接受&#xff0c;其中Scrum是最具代表性的敏捷方法之一。Scrum框架中有三个核心角色&#xff1a;Product Owner&#xff08;PO&#xff09;、Scrum Master&#xff08;SM&#xff09;和Development Team&#xff08;DT&#xff09;。…

模式组合应用-享元模式 - 详解

模式组合应用-享元模式 - 详解pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco"…

【Spring Boot】自定义starter

Spring Boot 自定义Starter 为什么要自定义Starter Spring Boot Starter 是一种简化依赖管理和自动配置的机制。下面详细介绍如何创建自定义 Starter。 Starter 的基本概念 命名规范 官方 Starter: spring-boot-star…

redis-bitMap类型基本命令

redis-bitMap类型基本命令BitMap是reids2.2.0版本中引入的一种新的数据类型。该数据类型本质上就是一个只包含0和1的二进制字符串。 它的所有命令都是对这个字符串二进制位的操作。字符串中的每个字符对应的索引称为of…

PrintNightmare漏洞仍未终结:深入解析PnP配置绕过与防护方案

本文深入分析了PrintNightmare漏洞的最新演变,详细介绍了攻击者如何通过DNS欺骗绕过Point and Print安全策略,并评估了UNC路径加固、RPC over SMB等多种防护方案的有效性。文章通过实际测试展示了防护措施的局限性,…

Go 1.26 内置函数 new 新特性

目前golang 1.26的各种新特性还在开发中,不过其中一个在开发完成之前就已经被官方拿到台面上进行宣传了——内置函数new功能扩展。 每个新特性其实都有它的背景故事,没有需求的驱动也就不会有新特性的诞生。所以在介…

基于SpringBoot及PostgreSQL的国家减肥食谱管理项目(上):区域与省份安装搭建

基于SpringBoot及PostgreSQL的国家减肥食谱管理项目(上):区域与省份安装搭建pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-f…

基于BP神经网络的激光焊接数据预测

基于BP神经网络的激光焊接数据预测的系统化方法,结合核心原理、实现步骤及工程优化策略,适用于焊接质量控制和工艺参数优化: 一、BP神经网络原理与激光焊接预测适配性核心机制 BP神经网络通过误差反向传播调整权重,…

重要公式 - Emi

重要的三角函数公式 \[sin\alpha cos\beta=\frac{sin(\alpha+\beta)+sin(\alpha-\beta)}{2} \]\[cos\alpha cos\beta=\frac{cos(\alpha+\beta)+cos(\alpha-\beta)}{2} \]\[sin\alpha sin\beta=-\frac{cos(\alpha+\beta…

Pandawiki:企业知识管理的全能管家

Pandawiki:企业知识管理的全能管家在当今这个信息爆炸的时代,每个企业都面临着一个共同的挑战:如何有效地管理和利用内部积累的海量知识资产?从产品文档到技术规范,从客户问答到项目经验,这些宝贵的信息往往散落…

珠宝网站建设做网站项目流程图模板

Spring的开发要点总结 文章目录 【JavaEE】Spring的开发要点总结&#xff08;1&#xff09;1. DI 和 DL1.1 DI 依赖注入1.2 DL 依赖查询1.3 DI 与 DL的区别1.4 IoC 与 DI/DL 的区别 2. Spring项目的创建2.1 创建Maven项目2.2 设置国内源2.2.1 勾选2.2.2 删除本地jar包2.2.3 re…

apt 还是 uv

一句话结论装系统级软件(C/CUDA、驱动、编译链) → 用 apt 纯 Python 项目/虚拟环境/依赖锁文件 → 用 uv;它比 apt 里的 python3-xxx 新、快、隔离,但不能装非 Python 组件下面给你展开对比,按“能干什么、不能干…

软件构造中的数据处理(sql) 6章

JDBC编程步骤 1.加载数据库驱动 2.建立数据库连接 3.创建Statement/PreparedStatement 4.执行SQL语句 5.处理查询结果(ResultSet) 6.关闭资源(Connection/Statement/ResultSet)

鹿鼎记豪侠传:Rust 重塑 iOS 江湖(下) - 指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

US$39 CAS Mileage Reset Authorization for CGDI Prog BMW MSV80 CAS1 CAS2 CAS3 CAS3+ via OBD

CAS Mileage Reset Authorization for CGDI Prog BMW MSV80 CAS1 CAS2 CAS3 CAS3+ via OBDWith this authorization, you can change mileage on BMW CAS1 CAS2 CAS3 CAS3+ CAS3++ via OBD.No need shipping. Please p…

是普通网站地图好还是rss地图好一点九江 网站建设

为增强安全性&#xff0c;平台可安装ssl证书。对于平台不同的组成部分需要采用不同的方式&#xff0c;使用不同的证书格式&#xff1a; 一、前端 前端采用nginx部署&#xff0c;安装证书步骤如下&#xff08;linux window版一样&#xff09;&#xff1a; 1、conf目录下增加cert…

树的重心(邻接表)

输入样例:9 1 2 1 7 1 4 2 8 2 5 4 3 3 9 4 6期望输出:4代码实现:#include<bits/stdc++.h> using namespace std;const int N =1e5+10 , M=2*N;int n,m; int h[N],e[M],ne[M],idx; bool vis[N]; int ans=N ;v…