BZOJ1775[USACO 2009 Dec Gold 3.Video Game Troubles]——DP
2024-08-27 00:25:02
题目描述
输入
* 第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
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]));
}
最新文章
- Windows 7 上安装Visual Studio 2015 失败解决方案
- c/c++常见面试题
- [LeetCode] Palindrome Permutation II 回文全排列之二
- Powershell 十个常见任务
- ARM汇编
- 定制个性化码表技术 ibus
- linux查看ssh用户登录日志与操作日志
- Nginx+Django+Uwsgi+php
- 一些常用的linux命令
- sliding windows (poj 2823) 题解
- node.js web开发:EXPRESS 4.x 以上使用session和cookie 的记录
- ASI简单实现网络编程
- drupal错误: Maximum execution time of 240 seconds exceeded
- centos7 用工具nmtui更改网卡设置
- HTTP之请求消息Request
- model,map,MapAndVivew用于页面跳转时候使用的即跳转后才添加属性 这样再回调中无法使用 因为回调的前提是页面不调转;解决的方法是用responsewrite(普通的字符响应)
- POI 导入excel 代码记录 方便以后粘贴
- 《JavaScript Dom 编程艺术》读书笔记-第7章
- 纯css3云彩动画效果
- HDU1004——Let the Balloon Rise
热门文章
- linux下模拟一个木马程序运行过程
- linux调度器源码分析 - 初始化(二)
- Tensorflow[架构流程]
- OpenStack中的虚拟机(/dev/mapper/centos-root)进行磁盘扩容
- angularjs的$window功能小练习
- 面试4——java进程和线程相关知识
- .NET日志记录之——log4net划重点篇
- Mongodb主从复制/ 副本集/分片集群介绍
- Python-dict-12
- Adobe Photoshop CC 2015使用及扩展工具