题目描述
皇家炼金师赫布瑞姆刚刚发明了一种用来折磨一切生物的新产品,灵魂分流药剂。灵魂分流药剂的妙处在于能够给服用者带来巨大的痛苦,但是却不会让服用者死去,而且可以阻止服用者的自杀。用它来对付敢于反对希尔瓦娜斯女王的狂徒们,简直是太精妙了。最近,侦察兵抓获了一个来自暴风城的人类探子,希尔瓦娜斯女王命令你用最痛苦的手段来折磨他。
你拥有N瓶药剂,按照成分配比的不同装在M个箱子中。每瓶药剂的有以下参数:对服用者造成的肉体伤害w,精神伤害v,所属的箱子t,和对服用者造成的痛苦程度p。人类探子的生命值为A,意志力为B。你只能从每个箱子中最多拿取1瓶药剂喂给他。注意,喂给他的药剂造成的总肉体伤害不能超过他的生命值A,否则他会死去,总的精神伤害不能超过他的意志力B,否则他会精神崩溃,我们没有必要给一个精神崩溃的傻瓜制造那么多痛苦。在不让他死去而且没有精神崩溃的前提下,你要尽可能给他制造更多的痛苦。这是女王的命令,如果你敢以任何理由或原因没有完成,你的下场就和他一样!
你拥有N瓶药剂,按照成分配比的不同装在M个箱子中。每瓶药剂的有以下参数:对服用者造成的肉体伤害w,精神伤害v,所属的箱子t,和对服用者造成的痛苦程度p。人类探子的生命值为A,意志力为B。你只能从每个箱子中最多拿取1瓶药剂喂给他。注意,喂给他的药剂造成的总肉体伤害不能超过他的生命值A,否则他会死去,总的精神伤害不能超过他的意志力B,否则他会精神崩溃,我们没有必要给一个精神崩溃的傻瓜制造那么多痛苦。在不让他死去而且没有精神崩溃的前提下,你要尽可能给他制造更多的痛苦。这是女王的命令,如果你敢以任何理由或原因没有完成,你的下场就和他一样!
输入
第1行:四个整数N,M,A,B,M个箱子的编号为1..M。
第2行至第N+1行:第i+1行四个整数w,v,t,p表示第i瓶药剂的肉体伤害,精神伤害,所属箱子的编号,和造成的痛苦值。
第2行至第N+1行:第i+1行四个整数w,v,t,p表示第i瓶药剂的肉体伤害,精神伤害,所属箱子的编号,和造成的痛苦值。
输出
第1行:一个整数,表示能够造成的最大的痛苦值。
输入样例复制
5 3 20 20
5 10 1 200
10 5 1 100
8 11 2 56
10 10 2 50
5 5 3 100
输出样例复制
300
说明
数据规模
对于30%的数据
N<=30
M<=5
对于100%的数据
N<=100
M<=10
A,B<=100
对于30%的数据
N<=30
M<=5
对于100%的数据
N<=100
M<=10
A,B<=100
分析
显然这是个背包,我们乍一看,有两个值是限制我们的所以01包
然后每个箱子还只能用一瓶,其实我们只需要把循环的顺序换一下就好了
先每个箱子->生命值->精神值->每瓶药剂 如果一个箱子可以取多瓶的话就放在箱子后面就可以啦
记得必须要大于药剂的伤害和精神
代码
1 #include<iostream> 2 #include<vector> 3 using namespace std; 4 struct sb 5 { 6 int w,v,t,p; 7 }a[1001]; 8 vector <int> k[1001]; 9 int f[1001][1001]; 10 int main () 11 { 12 int n,m,x,y; 13 cin>>n>>m>>x>>y; 14 for (int i=1;i<=n;i++) 15 { 16 cin>>a[i].w>>a[i].v>>a[i].t>>a[i].p; 17 k[a[i].t].push_back(i); 18 } 19 for (int i=1;i<=m;i++) 20 { 21 for (int c=x;c>=0;c--) 22 { 23 for (int d=y;d>=0;d--) 24 { 25 for (int j=0;j<k[i].size();j++) 26 { 27 int t=k[i][j]; 28 if (c>=a[t].w&&d>=a[t].v) 29 f[c][d]=max(f[c][d],f[c-a[t].w][d-a[t].v]+a[t].p); 30 } 31 32 } 33 } 34 } 35 cout<<f[x][y]; 36 }