zoukankan      html  css  js  c++  java
  • 暑假集训(5)第二弹———湫湫系列故事——减肥记I(hdu4508)

    问题描述:舔了舔嘴上的油渍,你陷在身后柔软的靠椅上。在德源大赛中获得优胜的你,迫不及待地赶到“吃到饱”饭店吃到饱。当你

    正准备离开时,服务员叫住了你,“先生,您还没有吃完你所点的酒菜。”指着你桌上的一片狼藉,不过仍有很多残余“军力”的景象。你刚刚还红光满面的脸一下变成霜打的茄子。看着桌上仍留的美食,正犯愁。“我可以帮你解决它。”你看向旁边,发现她也便是德源大赛

    的参赛者啾啾。还没来得及说谢谢。她便提出了条件,给出食物所含能量幸福度以及摄入最大能量限制,如何在不超过最大能量限制的

    情况下获得最大幸福度。

    问题分析:完全背包问题,当前状态更新如果(之前幸福度+新的幸福度)>当前幸福度。且能量不超过最大能量限制。

    状态转移方程为  dp[i] =max (dp[i-power[i]] + power[i],dp[i]);其中减去power[i]是为了得到之前幸福度.

     1 #include "cstdio"
     2 int happy[100];
     3 int oil[100];
     4 int dp[100004];
     5 void hbegin(int n)
     6 {
     7     for (int i=0;i<n;i++)
     8     {
     9         scanf ("%d%d",&happy[i],&oil[i]);
    10     }
    11     for (int i=0;i<100004;i++)
    12     {
    13         dp[i] = 0;
    14     }
    15 }
    16 int max(int x,int y)
    17 {
    18     return x>y?x:y;
    19 }
    20 int main()
    21 {
    22     int n,o;
    23     while (scanf ("%d",&n) != EOF)
    24     {
    25         hbegin(n);
    26         scanf ("%d",&o);
    27         for (int i=0;i<n;i++)
    28          {
    29             for (int j=oil[i];j<=o;j++)
    30             {
    31               dp[j] = max(dp[j-oil[i]]+happy[i],dp[j]);
    32             }
    33          }
    34      printf ("%d
    ",dp[o]);
    35     }
    36     return 0;
    37 }
    View Code
  • 相关阅读:
    bzoj1453
    276D
    855E
    bzoj1458
    树莓派 自启动连接阿里云物联网平台(一)
    树莓派 实现脚本程序自启动
    树莓派4B 系统镜像安装与boot配置
    2019-2020-2《网络对抗技术》 Exp1 PC平台逆向破解
    2019-2020-2 《网络对抗技术》 Exp0 kali 安装
    kali 添加使用 KDE 桌面环境
  • 原文地址:https://www.cnblogs.com/huas-zlw/p/5768382.html
Copyright © 2011-2022 走看看