混合背包--暗黑游戏(pgrune)

混合背包:包含着01背包,完全背包,多重背包

而这个题通过k[i]进行判断是哪个背包,少了个完全背包。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1000;
int vp[N];
int vr[N];
int k[N];
int w[N];
int f[151][151];
int main()
{
	int n,p,r;
	cin>>n>>p>>r;
	for(int i=1;i<=n;i++)
	{
		cin>>vp[i]>>vr[i]>>k[i]>>w[i];	
	}
	f[0][0]=0;
	for(int i=1;i<=n;i++)
	{
        //01背包
		if(k[i]==1)
		{
			for(int j=p;j>=vp[i];j--)
			{
				for(int x=r;x>=vr[i];x--)
				{
					for(int u=0;u<=k[i];u++)
				{
					if(u*vp[i]<=j&&u*vr[i]<=x)
					f[j][x]=max(f[j][x],f[j-vp[i]*u][x-vr[i]*u]+w[i]*u);
				}
				}
			}
		}
        //多重背包
		else if(k[i]==0)
		{
			for(int j=p;j>=vp[i];j--)
			{
				for(int x=r;x>=vr[i];x--)
				{
					for(int u=0;u<=1e5;u++)
					{
						if(u*vp[i]>j||u*vr[i]>x)
						break;
						f[j][x]=max(f[j][x],f[j-vp[i]*u][x-vr[i]*u]+w[i]*u);
					}
				}
			}
		}
        //多重背包
		else 
		{
			for(int j=p;j>=vp[i];j--)
			{
				for(int x=r;x>=vr[i];x--)
				{
					for(int u=0;u<=k[i];u++)
					{
						if(u*vr[i]<=x&&u*vp[i]<=j)
						f[j][x]=max(f[j][x],f[j-vp[i]*u][x-vr[i]*u]+w[i]*u);
					}
				}
			}
		}
	}
	cout<<f[p][r]<<endl;
	return 0;
}
相关推荐
焦耳加热3 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn3 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6064 小时前
常用排序算法核心知识点梳理
算法·排序
蒋星熠6 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油6 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream6 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL6 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法
空白到白7 小时前
机器学习-聚类
人工智能·算法·机器学习·聚类
索迪迈科技7 小时前
java后端工程师进修ing(研一版 || day40)
java·开发语言·学习·算法
zzzsde7 小时前
【数据结构】队列
数据结构·算法