[AT_cf_2015_relay_g]题解

洛谷链接&ATcoder链接

题目翻译:

您将从 n n n 种主菜和 m m m 种副菜中选择菜品来创建一道套餐。您只能选择一种主菜,但可以选择任意数量的副菜。此外,也可以选择不选任何副菜。无论是主菜还是副菜,每种菜品只能选择一道。

题意简述:

首先明确一下这道题是01背包,即每个物品只能选一次,题目中所说的 m m m 物品和 n n n 物品其实是 m m m 物品和 n n n 物品。并且主菜必须选且只能选一个。

思路分析:

可以先用01背包维护副菜, d p [ i ] [ j ] dp[i][j] dp[i][j] 表示到第 i i i 个物品为止,花费 j j j 元钱可以得到的最大美味度。其中 1 ≤ i ≤ m 1\le i \le m 1≤i≤m, 0 ≤ j ≤ l − m i n ( a 1 , a 2 , . . . , a n − 1 , a n ) 0\le j\le l-min(a_1,a_2,...,a_n-1,a_n) 0≤j≤l−min(a1,a2,...,an−1,an)。然后,枚举所有主菜,比较并更新美味度最大值。

代码:

cpp 复制代码
#include<iostream>
using namespace std;
struct node{
	int w,v;//w价钱,v美味度
}zhu[10010],fu[1010];//zhu主材,fu副菜
int n,m,l,dp[1010][10010],ans;//ans记录答案
int main(){
	int minn=0x3f3f3f3f;
	cin>>n>>m>>l;
	for(int i=1;i<=n;i++){
		cin>>zhu[i].w>>zhu[i].v;
		minn=min(minn,zhu[i].w);//求主材价格最小值
	}
	for(int i=1;i<=m;i++){
		cin>>fu[i].w>>fu[i].v;
	}
	//01背包维护副菜
	for(int i=1;i<=m;i++){
		for(int j=0;j<=l-minn;j++){//优化:至少要给最便宜的主菜留出钱
			if(j>=fu[i].w){//判断越界 (是否可以买)
				dp[i][j]=max(dp[i-1][j],dp[i-1][j-fu[i].w]+fu[i].v);//状态转移 (01背包)
			}else{
				dp[i][j]=dp[i-1][j];
			}
		}
	}
	for(int i=1;i<=n;i++){//枚举主菜
		if(l>=zhu[i].w){//判断越界 (是否可以买)
			ans=max(ans,dp[m][l-zhu[i].w]+zhu[i].v);//更新答案最大值
		}
	}
	cout<<ans<<endl;//输出答案
	return 0;
}
相关推荐
张张努力变强5 分钟前
C++类和对象(一):inline函数、nullptr、类的定义深度解析
开发语言·前端·jvm·数据结构·c++·算法
且去填词25 分钟前
深入理解 GMP 模型:Go 高并发的基石
开发语言·后端·学习·算法·面试·golang·go
Hcoco_me38 分钟前
大模型面试题76:强化学习中on-policy和off-policy的区别是什么?
人工智能·深度学习·算法·transformer·vllm
企业对冲系统官42 分钟前
大宗商品风险对冲系统统计分析功能的技术实现
运维·python·算法·区块链·github·pygame
ValhallaCoder43 分钟前
Day48-单调栈
数据结构·python·算法·单调栈
Sylvia-girl1 小时前
数组题目之移除元素
算法
foundbug9991 小时前
小波分析与粒子群算法结合用于电网潮流优化
算法
Morwit1 小时前
*【力扣hot100】 448. 找到所有数组中消失的数字
数据结构·算法·leetcode
朔北之忘 Clancy1 小时前
第二章 分支结构程序设计(2)
c++·算法·青少年编程·竞赛·教材·考级·讲义
FAFU_kyp2 小时前
Rust 流程控制学习教程
学习·算法·rust