混合背包--暗黑游戏(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;
}
相关推荐
浅念-4 小时前
刷穿LeetCode:BFS 解决 Flood Fill 算法
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
做cv的小昊5 小时前
【TJU】研究生应用统计学课程笔记(8)——第四章 线性模型(4.1 一元线性回归分析)
笔记·线性代数·算法·数学建模·回归·线性回归·概率论
贾斯汀玛尔斯5 小时前
每天学一个算法--倒排索引(Inverted Index)
算法·inverted-index
小e说说5 小时前
打破偏科困境:这些学习软件助孩子重燃学习热情
算法
月昤昽6 小时前
autoCAD二次开发 4.正多边形与collection区分
算法·c#·二次开发·autocad二次开发
休息一下接着来6 小时前
C++ 固定容量环形队列实现
c++·算法
im_AMBER7 小时前
手撕hot100之矩阵!看完这篇就AC~
javascript·数据结构·线性代数·算法·leetcode·矩阵
笨笨饿7 小时前
#79_NOP()嵌入式C语言中内联汇编宏的抽象封装模式研究
linux·c语言·网络·驱动开发·算法·硬件工程·个人开发
风萧萧19998 小时前
问答样例如何在RAG问答中使用?
算法