• SSLOJ 1317.灵魂分流药剂


    题目描述

    皇家炼金师赫布瑞姆刚刚发明了一种用来折磨一切生物的新产品,灵魂分流药剂。灵魂分流药剂的妙处在于能够给服用者带来巨大的痛苦,但是却不会让服用者死去,而且可以阻止服用者的自杀。用它来对付敢于反对希尔瓦娜斯女王的狂徒们,简直是太精妙了。最近,侦察兵抓获了一个来自暴风城的人类探子,希尔瓦娜斯女王命令你用最痛苦的手段来折磨他。
     
    你拥有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瓶药剂的肉体伤害,精神伤害,所属箱子的编号,和造成的痛苦值。

    输出

    第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
     
     

    分析

        显然这是个背包,我们乍一看,有两个值是限制我们的所以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 }
    为何要逼自己长大,去闯不该闯的荒唐
  • 相关阅读:
    Linux LCD驱动(四)--驱动的实现
    Linux LCD驱动(三)--图形显示
    s3c2440的LCD字符显示
    Linux framebuffer显示bmp图片
    Linux Framebuffer编程简介
    linux 2440 LCD 应用程序编程
    嵌入式Linux下S3C2410的调色板彩色显示
    l​i​n​u​x​下​L​C​D​(​f​r​a​m​e​b​u​f​f​e​r​)​驱​动​分​析
    我的基本信息
    unity生命周期
  • 原文地址:https://www.cnblogs.com/zjzjzj/p/10778872.html
Copyright © 2020-2023  润新知