题目描述

输入

* 第1行: 两个由空格隔开的整数: N和V * 第2到第N+1行: 第i+1行表示第i种游戏平台的价格和可以在这种游戏平台上面运行的游 戏。包含: P_i, G_i还有G_i对由空格隔开的整数GP_j, PV_j

输出

* 第1行: 农夫约翰在预算内可以得到的最大的产出值。

样例输入

3 800
300 2 30 50 25 80
600 1 50 130
400 3 40 70 30 40 35 60

样例输出

210
 
一看到这题第一感觉就是背包,这题确实就是背包,只不过和平常的背包有些不同,在卖一些东西之前要先买另一个东西,而且这个东西还没有价值(虽然有没有价值不太重要qwq)。既然买游戏的前提是买游戏平台,那么我们不妨以是否买游戏平台做状态来转移,设f[i][j]代表不买第i个游戏平台总共花了j元的最大价值、g[i][j]代表买第i个游戏平台总共花了j元的最大价值。对于买了游戏平台的状态(也就是每个g[i][j])再对它包含的游戏进行状态转移。但要注意数组初始值要赋成极小值来避免无用状态的转移。
最后附上代码。
#include<queue>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,m;
int x,y;
int v,c;
int g[51][100010];
int f[51][100010];
int main()
{
scanf("%d%d",&n,&m);
memset(g,0x80,sizeof(g));
memset(f,0x80,sizeof(f));
for(int i=0;i<=m;i++)
{
g[0][i]=f[0][i]=0;
}
for(int i=1;i<=n;i++)
{
scanf("%d%d",&v,&c);
for(int j=0;j<=m;j++)
{
f[i][j]=max(f[i-1][j],g[i-1][j]);
if(v<=j)
{
g[i][j]=max(g[i-1][j-v],f[i-1][j-v]);
}
}
while(c--)
{
scanf("%d%d",&x,&y);
for(int j=m;j>=v;j--)
{
g[i][j]=max(g[i][j],g[i][j-x]+y);
}
}
}
printf("%d",max(f[n][m],g[n][m]));
}

最新文章

  1. Windows 7 上安装Visual Studio 2015 失败解决方案
  2. c/c++常见面试题
  3. [LeetCode] Palindrome Permutation II 回文全排列之二
  4. Powershell 十个常见任务
  5. ARM汇编
  6. 定制个性化码表技术 ibus
  7. linux查看ssh用户登录日志与操作日志
  8. Nginx+Django+Uwsgi+php
  9. 一些常用的linux命令
  10. sliding windows (poj 2823) 题解
  11. node.js web开发:EXPRESS 4.x 以上使用session和cookie 的记录
  12. ASI简单实现网络编程
  13. drupal错误: Maximum execution time of 240 seconds exceeded
  14. centos7 用工具nmtui更改网卡设置
  15. HTTP之请求消息Request
  16. model,map,MapAndVivew用于页面跳转时候使用的即跳转后才添加属性 这样再回调中无法使用 因为回调的前提是页面不调转;解决的方法是用responsewrite(普通的字符响应)
  17. POI 导入excel 代码记录 方便以后粘贴
  18. 《JavaScript Dom 编程艺术》读书笔记-第7章
  19. 纯css3云彩动画效果
  20. HDU1004——Let the Balloon Rise

热门文章

  1. linux下模拟一个木马程序运行过程
  2. linux调度器源码分析 - 初始化(二)
  3. Tensorflow[架构流程]
  4. OpenStack中的虚拟机(/dev/mapper/centos-root)进行磁盘扩容
  5. angularjs的$window功能小练习
  6. 面试4——java进程和线程相关知识
  7. .NET日志记录之——log4net划重点篇
  8. Mongodb主从复制/ 副本集/分片集群介绍
  9. Python-dict-12
  10. Adobe Photoshop CC 2015使用及扩展工具