CF715B Complete The Graph 题解
Description
给
修改
Solution
考虑怎么判有无解。
容易发现将所有未知边边权设为
不妨设
考虑再进行一次 dijkstra,如果当前松弛的边
时间复杂度:
Code
#include <bits/stdc++.h> #define int int64_t const 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 ORZXKR freopen("in.txt", "r", stdin); freopen("out.txt", "w", stdout); #endif std::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; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】