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;
}
相关推荐
攻城狮Soar32 分钟前
STL源码解析之list(1)
开发语言·c++
2401_8697695937 分钟前
内容5 日期类实现
开发语言·c++
xxwl58540 分钟前
一个原创题(二)
c++·算法
MZZ骏马1 小时前
C++ 极简模式的日志
c++
AbandonForce2 小时前
滑动窗口:定长滑动窗口与不定长滑动窗口
数据结构·c++·算法
小欣加油2 小时前
leetcode3689最大子数组总值I
c++·算法·leetcode·职场和发展·贪心算法
有点。2 小时前
C++(贪心算法二)
开发语言·c++·贪心算法
有点。2 小时前
C++贪心算法一(练习题)
开发语言·c++·贪心算法
Coder-magician2 小时前
《代码随想录》刷题打卡day12:二叉树part02
数据结构·c++·算法
随意起个昵称3 小时前
线性dp-LIS题目5(导弹拦截,二分优化)
c++·算法·动态规划