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

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

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

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;
}
相关推荐
To_OC15 小时前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC15 小时前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK17 小时前
线段树维护区间 k 次方和
c++·数学·算法·stl
_清歌1 天前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局1 天前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象1 天前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局1 天前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法
统计实现局1 天前
dqrsl 拆解:拿着 QR 结果能算出哪 5 种东西
算法
统计实现局1 天前
为什么 Cholesky 求逆比 Gauss-Jordan 快一倍——行列式溢出防护详
算法