河南萌新联赛2024第(三)场:河南大学 I - 游戏

河南萌新联赛2024第(三)场:河南大学 I - 游戏

无向图最小花费路径问题

给定一个无向图,包含n个节点和m条边。每条边有一个通过的花费,并且附带一个状态信息:

  • 状态为0:表示该边当前处于锁定状态,暂时不可通过。
  • 状态为1:表示该边可以通行。

特别地,在节点k处藏有一把钥匙,一旦取得这把钥匙,就可以解锁所有状态为0的边,使其变为可通行状态。

目标:从节点1出发,找到一条到达节点n的路径,使得这条路径上的总花费最小。

输入描述:

第一行三个整数 n , m , k n,m,k n,m,k ,分别表示节点数,边数,钥匙所在节点

接下来 m m m 行,每行四个整数 a i , b i , c i , d i a_i ,b_i ,c_i ,d_i ai,bi,ci,di​,表示 到 b_i之间存在一条无向边,通过该边花费 c i c_i ci,其状态为 d i d_i di,取值仅为 0 或 1

输出描述:

输出节点 1 到 n 的最小花费,如果无法到达,输出 −1

输入
cpp 复制代码
6 10 5
1 2 1 1
2 4 9 1
4 5 4 1
1 3 9 1
3 6 8 0
4 6 6 0
4 5 1 0
5 6 10 0
5 6 5 0
5 6 6 1
输出
cpp 复制代码
19
输入
cpp 复制代码
6 10 5
1 6 4 1
6 3 9 1
3 5 8 1
1 2 10 0
3 4 2 1
4 5 2 0
3 4 5 1
3 6 6 1
5 6 1 0
3 5 10 1
输出
cpp 复制代码
4
  • n n n 的取值范围: 1 ≤ n ≤ 2 × 1 0 5 1 \leq n \leq 2 \times 10^5 1≤n≤2×105
  • m m m 的取值范围: 0 ≤ m ≤ 1 0 5 0 \leq m \leq 10^5 0≤m≤105
  • k , a i , b i k, ai, bi k,ai,bi 的取值范围: 1 ≤ k , a i , b i ≤ n 1 \leq k, ai, bi \leq n 1≤k,ai,bi≤n
  • c i ci ci 的取值范围: 1 ≤ c i ≤ 2 × 1 0 5 1 \leq ci \leq 2 \times 10^5 1≤ci≤2×105
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

typedef long long LL;
typedef tuple<LL, int, int> tup;

signed main()
{
	int n, m, k;
	cin >> n >> m >> k;
	vector<vector<tup>> g(n + 1);
	while (m--)
	{
		int a, b, c, d;
		cin >> a >> b >> c >> d;
		g[a].push_back({b, c, d});
		g[b].push_back({a, c, d});
	}
	vector<vector<LL>> dis(n + 1, vector<LL>(2, 1e11));
	priority_queue<tup, vector<tup>, greater<tup>> Q;
	Q.push({0, 1, k == 1});
	while (!Q.empty())
	{
		auto [distance, u, ok] = Q.top();
		Q.pop();
		if (dis[u][ok] != 1e11) continue;
		dis[u][ok] = distance;
		for (auto [v, w, x] : g[u])
		{
			int is_k = ok == 1 || v == k;
			if (x == 1 || ok) Q.push({distance + w, v, is_k});
		}
	}
	LL ans = min(dis[n][0], dis[n][1]);
	if (ans == 1e11) ans = -1;
	cout << ans << "\n";
	return 0;
}
相关推荐
悦来客栈的老板2 小时前
AST反混淆实战|reese84_jsvmp反编译前的优化处理
java·前端·javascript·数据库·算法
dragoooon342 小时前
[优选算法专题十一.字符串 ——NO.60~63 最长公共前缀、5最长回文子串、 二进制求和 、字符串相乘]
算法·leetcode·动态规划
lengxuenong2 小时前
第四届挑战赛二轮题解
c++·算法
小毅&Nora2 小时前
【后端】【C++】函数对象与泛型算法:从“找最便宜的菜”说起
c++·算法·泛型
CoderYanger2 小时前
C.滑动窗口——2762. 不间断子数组
java·开发语言·数据结构·算法·leetcode·1024程序员节
2401_837088502 小时前
Integer.MIN_VALUE 是什么意思?
java·开发语言·算法
好风凭借力,送我上青云2 小时前
哈夫曼树和哈夫曼编码
c语言·开发语言·数据结构·c++·算法·霍夫曼树
程序员-King.2 小时前
day118—二分查找—咒语和药水的成功对数(LeetCode-2300)
算法·leetcode·二分查找
小O的算法实验室2 小时前
2025年COR SCI2区,双种群 NSGA-II 算法+卡车–无人机–调度车辆的多目标应急物资调度,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
KiefaC2 小时前
【C++】红黑树的调整
开发语言·c++·算法