CF715B Complete The Graph 题解

news/2024/11/18 20:11:38/文章来源:https://www.cnblogs.com/Scarab/p/18553531

Description

\(n\)\(m\) 边的无向图,\(L\)\(s\)\(t\)

修改 \(m\) 条边中边为 \(0\) 的边,使满足 \(s,t\) 的最短路长度是 \(L\),且输出答案的时候边为 \(0\) 的边的权值必须在 \([1,10^{18}]\) 内。

Solution

考虑怎么判有无解。

容易发现将所有未知边边权设为 \(10^{18}\),如果最短路小于 \(L\),或者未知边设为 \(1\) 后最短路大于 \(L\) 时无解,否则有解。因为每次只将一条边的长度加 \(1\) 后最短路至多增加 \(1\)

不妨设 \(dis_i\) 表示 \(i\) 在未知边边权为 \(1\) 时与 \(s\) 的距离,\(det\) 表示 \(L-dis_t\)。容易发现我们的任务就是让 \(dis_t\) 增加 \(det\)

考虑再进行一次 dijkstra,如果当前松弛的边 \((u,v,w)\),满足 \(dis_{v}+det>dis^{'}_{u}+w\),就将 \(w\) 调整为 \(dis_{v}+det-dis^{'}_u\) 后再松弛,这样的话每个点的最短路一定不会增加超过 \(det\),且 \(dis_t\) 一定能增加 \(det\)

时间复杂度:\(O((n+m)\log n)\)

Code

#include <bits/stdc++.h>#define int int64_tconst int kMaxN = 1e3 + 5, kMaxM = 1e4 + 5;int n, m, L, s, t, det;
int u[kMaxM], v[kMaxM], w[kMaxM];
int dis1[kMaxN], dis2[kMaxN];
bool del[kMaxM];
std::vector<std::tuple<int, int, int>> G[kMaxN];int dijkstra1(int *dis) {static bool vis[kMaxN];for (int i = 1; i <= n; ++i) G[i].clear();for (int i = 1; i <= m; ++i) {if (w[i]) {G[u[i]].emplace_back(v[i], w[i], i), G[v[i]].emplace_back(u[i], w[i], i);}}for (int i = 1; i <= n; ++i) {dis[i] = 1e18, vis[i] = 0;}std::priority_queue<std::pair<int, int>> q;q.emplace(0, s), dis[s] = 0;for (; !q.empty();) {int u = q.top().second; q.pop();if (vis[u]) continue;vis[u] = 1;for (auto [v, w, id] : G[u]) {if (dis[v] > dis[u] + w) {dis[v] = dis[u] + w;q.emplace(-dis[v], v);}}}return dis[t];
}int dijkstra2(int *dis) {static bool vis[kMaxN];for (int i = 1; i <= n; ++i) G[i].clear();for (int i = 1; i <= m; ++i) {if (w[i]) {G[u[i]].emplace_back(v[i], w[i], i), G[v[i]].emplace_back(u[i], w[i], i);}}for (int i = 1; i <= n; ++i) {dis[i] = 1e18, vis[i] = 0;}std::priority_queue<std::pair<int, int>> q;q.emplace(0, s), dis[s] = 0;for (; !q.empty();) {int u = q.top().second; q.pop();if (vis[u]) continue;vis[u] = 1;for (auto [v, w, id] : G[u]) {if (del[id] && dis1[v] + det > dis[u] + ::w[id])::w[id] = dis1[v] + det - dis[u];if (dis[v] > dis[u] + ::w[id]) {dis[v] = dis[u] + ::w[id];q.emplace(-dis[v], v);}}}return dis[t];
}void print() {std::cout << "YES\n";for (int i = 1; i <= m; ++i)std::cout << u[i] - 1 << ' ' << v[i] - 1 << ' ' << w[i] << '\n';
}void dickdreamer() {std::cin >> n >> m >> L >> s >> t;++s, ++t;for (int i = 1; i <= m; ++i) {std::cin >> u[i] >> v[i] >> w[i];++u[i], ++v[i];if (!w[i]) del[i] = 1, w[i] = 1e18;}int dis = dijkstra1(dis1);if (dis < L) return void(std::cout << "NO\n");if (dis == L) return print();for (int i = 1; i <= m; ++i)if (del[i])w[i] = 1;int now = dijkstra1(dis1);if (now > L) return void(std::cout << "NO\n");det = L - now;dijkstra2(dis2);print();
}int32_t main() {
#ifdef ORZXKRfreopen("in.txt", "r", stdin);freopen("out.txt", "w", stdout);
#endifstd::ios::sync_with_stdio(0), std::cin.tie(0), std::cout.tie(0);int T = 1;// std::cin >> T;while (T--) dickdreamer();// std::cerr << 1.0 * clock() / CLOCKS_PER_SEC << "s\n";return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/836358.html

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

相关文章

测试工程师的苦水与解药:别让这些问题毁了你的职业生涯!

咱这些测试工程师啊,外人瞅着好像工作挺简单,不就是找找软件的毛病嘛。可实际上,这里面的苦啊,就像那一团乱麻,扯都扯不清,全是无奈和心酸。 加班加到“怀疑人生” 咱这加班啊,那可真是没个头。经常整到深更半夜,感觉自己都快不是个人了,身体那是越来越差,就像个破机…

使用VS2022打开解决方案后每个项目都显示“不兼容”

1、问题描述 今天本地使用VS2022打开之前新建的项目(.Net6框架),突然出现每个项目都显示“不兼容”的问题,导致每个项目的文件都看不到了,如下图所示:2、解决办法 鼠标右键解决方案,然后选择“解析错误”选项,等待一会所有的项目即可显示出来了,如下图所示:到此,问题…

数据采集与融合技术第四次作业

作业内容 作业①: 要求: 熟练掌握 Selenium 查找HTML元素、爬取Ajax网页数据、等待HTML元素等内容。 使用Selenium框架+ MySQL数据库存储技术路线爬取“沪深A股”、“上证A股”、“深证A股”3个板块的股票数据信息。 候选网站:东方财富网:http://quote.eastmoney.com/center…

【Visio 2024软件下载与安装教程-亲测好用】

Microsoft Visio 2024专业版是一款专业的专业矢量绘图软件。Visio 2024不但新增了许多功能,而且还优化了众多性能,比如用户界面优化、更多图形元素库、允许用户邀请其他人一起编辑和查看图表、过程自动化等等,其一系列的改动旨在给予用户们最直观、最便利的操作体验! 操作系…

工作服穿戴识别系统

工作服穿戴识别系统利用现场装好的监控摄像头24小时对工作场景进行实时监测。工作服穿戴识别系统一旦检测到员工工服穿戴不符合规定的情况,系统能够立即发出警报,提醒相关人员进行处理。通过实时监控和精准报警,工作服穿戴识别系统能够有效规范作业人员的行为。员工知道自己…

桥梁大师_钢筋图_配置汇总

1.2米桩基_【正常】 1.2米桩基_【配抗震钢筋】

值班睡岗智能监测系统

值班睡岗智能监测系统是一种利用人工智能技术,值班睡岗智能监测系统通过现场已有的摄像头进行实时视频分析的系统。系统能够自动识别监测现场人员是否在岗位上,一旦检测到离岗或睡岗行为,系统会实时抓拍并触发报警,将报警信息传送至后台监控平台。系统能够替代人工进行长时…

使用 Nginx Ingress 实现金丝雀发布/灰度发布

使用 Nginx Ingress 实现金丝雀发布/灰度发布 说明: 使用 Nginx Ingress 实现金丝雀发布的集群,需部署 Nginx Ingress 作为 Ingress Controller,并且对外暴露统一的流量入口。详情请参见 在 TKE 上部署 Nginx Ingress。 使用场景 使用 Nginx Ingress 实现金丝雀发布适用场景…

# 20222309 2024-2025-1 《网络与系统攻防技术》实验六实验报告

1.实验内容 本实践目标是掌握metasploit的用法。 指导书参考Rapid7官网的指导教程。 https://docs.rapid7.com/metasploit/metasploitable-2-exploitability-guide/ 下载官方靶机Metasploitable2,完成下面实验内容。 (1)前期渗透 ①主机发现(可用Aux中的arp_sweep,search一…

如何在开源鸿蒙OpenHarmony开启SELinux模式?RK3566鸿蒙开发板演示

本文介绍开源鸿蒙OpenHarmony系统下,开启/关闭SELinux权限的方法,触觉智能Purple Pi OH鸿蒙开发板演示,已适配全新OpenHarmony5.0 Release系统!本文介绍在开源鸿蒙OpenHarmOony系统下,开启/关闭SELinux权限的方法,触觉智能Purple Pi OH鸿蒙开发板演示,搭载了瑞芯微RK356…

locust(服务器压测)

一: 注意事项:项目和压力机不能在同一台机器 二: 1.脚本压测 命令行:locust -f get.py --host=http:ip+host 注意事项Wait_time写0,0 不进行等待 1.脚本压测 2.1服务器防火墙需要关闭 2.2需要把打印去掉 2.3 Download Data 下载报告三.非web模式新版中 -u 指的是多少 用户/…

旺仔水饺-冲刺总结

1. 冲刺内容总结与反思 1.1 项目总结 本次冲刺阶段对项目的不足之处进行了相关改进: 针对团队沟通问题: 我们在本次冲刺阶段几乎是每天召开团队会议,包括沟通效率比较高的的站立会议;我们站立会议每次召开十分钟,尽量在这个十分钟之内大家都都把自己当前进行的的功能模块遇…