P7082 [NWRRC 2013] Dwarf Tower 完全背包

古老但是没有通过的洛谷题解,只能放到这里安慰我受伤的心灵了

P7082 [NWRRC 2013] Dwarf Tower

题目描述

小 Vasya 在玩一个新游戏叫做 Dwarf Tower。在这个游戏中有 nnn 个不同的衣物给你的矮人。衣物从 111 到 nnn 进行编号。Vasya 想要获得编号为 111 的衣物。

现在有两种方法获得一件衣物:

  1. 你可以买它,第 iii 件物品花费 cic_ici 元。

  2. 你还可以制作它,这个游戏支持 mmm 种制作方法。要制作一个衣物,你需要花费两个特定的衣物。

算出 Vasya 至少需要多少钱来获得一号衣物。

输入格式

第一行输入两个整数 nnn , mmm (1 \\le n \\le 10000 , 0 \\le m \\le 100000) 代表有 nnn 种衣物和有 mmm 种制作方法。

第二行输入 nnn 个整数,第 iii 个整数代表 cic_ici (0≤ci≤109)(0 \le c_i \le 10^9)(0≤ci≤109) 。

接下来 mmm 行每行有三个整数 ai,xi,yia_i, x_i, y_iai,xi,yi (1≤ai,xi,yi≤n,ai≠xi,xi≠yi,yi≠ai)(1 \le a_i, x_i, y_i \le n , a_i \ne x_i, x_i \ne y_i, y_i \ne a_i)(1≤ai,xi,yi≤n,ai=xi,xi=yi,yi=ai) ,aia_iai 代表 aia_iai 可以被 xix_ixi 和 yiy_iyi 制作。

输出格式

一个整数,代表 Vasya 至少需要多少钱来获得一号衣物。

输入输出样例 #1

输入 #1

复制代码
5 3
5 0 1 2 5
5 2 3
4 2 3
1 4 5

输出 #1

复制代码
2

思路

这道题目我有一个非常奇怪的思路(背包)

我们会发现直接买制作(合成)是两种状态,由于所有衣物都可以拥有无数个 ,所以是个完全背包

令 cic_ici 表示第 iii 件物品的价格 , aia_iai,xix_ixi,yiy_iyi 表示第 aia_iai 件物品可以由第 xix_ixi 和第 yiy_iyi 件物品制作 ,则:cai=min(cai,cxi+cyi)c_{a_i} = min(c_{a_i} , c_{x_i}+c_{y_i})cai=min(cai,cxi+cyi)

代码:

这是我好久前的码风了。。。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,m,c[100005],a[100005],x[100005],y[100005];
int main(){
	ios::sync_with_stdio(0);
	cin>>n>>m;
	for(int i=1;i<=n;i++)cin>>c[i];
	for(int i=1;i<=m;i++)cin>>a[i]>>x[i]>>y[i];
	for(int i=1;i<n;i++)
		for(int j=1;j<=m;j++)
			c[a[j]]=min(c[a[j]],c[x[j]]+c[y[j]]);
	cout<<c[1];
	return 0;
}
相关推荐
charlie1145141912 小时前
通用GUI编程技术——图形渲染实战(三十八)——顶点缓冲与输入布局:GPU的第一个三角形
开发语言·c++·学习·图形渲染·win32
用户805533698032 小时前
现代Qt开发教程(新手篇)1.10——进程
c++·qt
海参崴-2 小时前
C++ STL篇 AVL树的模拟实现
开发语言·c++
汉克老师2 小时前
GESP2025年6月认证C++五级( 第二部分判断题(1-10))
c++·贪心算法·分治算法·线性筛法·gesp5级·gesp五级
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 15. 三数之和 | C++ 排序+双指针
c++·算法·leetcode
vegetablesssss2 小时前
VTK切割图
c++·qt·vtk
CN-Dust3 小时前
【C++】for循环例题专题
java·c++·算法
IOT那些事儿3 小时前
Qt5 VSCode调试
c++·vscode·mingw·qt5
c++之路3 小时前
C++ 多线程
开发语言·c++
故事和你913 小时前
洛谷-算法2-3-分治与倍增5
开发语言·数据结构·c++·算法·动态规划·图论