HihoCoder - 1038 01背包 动态规划
#1038 : 01背包
时间限制:20000ms
单点时限:1000ms
内存限制:256MB
描述
且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励的时刻了!
小Ho现在手上有M张奖券,而奖品区有N件奖品,分别标号为1到N,其中第i件奖品需要need(i)张奖券进行兑换,同时也只能兑换一次,为了使得辛苦得到的奖券不白白浪费,小Ho给每件奖品都评了分,其中第i件奖品的评分值为value(i),表示他对这件奖品的喜好值。现在他想知道,凭借他手上的这些奖券,可以换到哪些奖品,使得这些奖品的喜好值之和能够最大。
输入
每个测试点(输入文件)有且仅有一组测试数据。
每组测试数据的第一行为两个正整数N和M,表示奖品的个数,以及小Ho手中的奖券数。
接下来的n行描述每一行描述一个奖品,其中第i行为两个整数need(i)和value(i),意义如前文所述。
测试数据保证
对于100%的数据,N的值不超过500,M的值不超过10^5
对于100%的数据,need(i)不超过2*10^5, value(i)不超过10^3
输出
对于每组测试数据,输出一个整数Ans,表示小Ho可以获得的总喜好值。
样例输入
5 1000
144 990
487 436
210 673
567 58
1056 897
样例输出
2099
题解:01背包模板题,所求的是n种商品、m张奖券能兑换的最大价值,可以转化为遍历i种奖品奖券数为j时获取的最大值(dp[i][j]),然后取max( i奖品的价值+剩下奖券能获取的最大价值 ,原来奖券数为j时的最大价值)为奖券数为j时获取的最大值(原理就是比较使用同样多的奖券加入i奖品组合后是否能产生更大价值),dp[i][j]=max(dp[i-1][j],dp[i-1][j-need[i]]+val[i]),为了减小复杂度,我们可以将dp变成一维数组,只记录奖券数为j时当前最大价值,从表上可以发现,每次增加奖品dp数据更新判断时只使用上一行中小于等于j的数据,所以采取从后往前遍历的方法避免数据使用冲突,同时我们可以一边输入一边更新,不用储存各种奖品对应的奖券数和价值,dp[j]=max(dp[j],dp[j-need+val);(dp漫画讲解:https://www.jianshu.com/p/e200805306db)
//一般解法 时间:2625ms 内存:202MB
#include<iostream>
#include<algorithm>
#include<string.h>
using namespace std;
int dp[505][100011];
int need[505],val[505];
int main()
{
int n,m;
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++)
scanf("%d %d",&need[i],&val[i]);
memset(dp,0,sizeof(dp));
//dp[i][j]就是奖券数为j时遍历i种产品的最大价值
for(int i=1;i<=n;i++){//第i件奖品
for(int j=1;j<=m;j++){//消耗的奖券数
if(!i){//小于need[i]时该奖品不产生影响
if(j>=need[i])
dp[i][j]=val[i];
}else{
if(j>=need[i])
dp[i][j]=max(dp[i-1][j],dp[i-1][j-need[i]]+val[i]);
//dp[i-1][j-need[i]]表示减去i奖品所需奖券数能取得的最大价值(在上一奖品中已经求出)
//若i奖品的价值+剩下奖券能获取的最大价值>原来奖券数为j时的最大价值,则更新奖券数为j时的最大价值
else//小于need[i]时该奖品不产生影响
dp[i][j]=dp[i-1][j];
}
}
}
printf("%d\n",dp[n][m]);
return 0;
}
//优化解法 时间:143ms 内存:0MB
#include<iostream>
#include<algorithm>
#include<string.h>
using namespace std;
int dp[100011];
int main()
{
int n,m,need,val;
scanf("%d %d",&n,&m);
memset(dp,0,sizeof(dp));
//dp[j]就是奖券数为j当前最大价值
for(int i=1;i<=n;i++){//第i件奖品
scanf("%d %d",&need,&val);
for(int j=m;j>=need;j--)
dp[j]=max(dp[j],dp[j-need]+val);
}
printf("%d\n",dp[m]);
return 0;
}
HihoCoder - 1038 01背包 动态规划的更多相关文章
- hihoCoder #1038 : 01背包(板子题)
#1038 : 01背包 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励 ...
- hihocoder 1038 01背包
#1038 : 01背包 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励 ...
- hiho #1038 : 01背包 (dp)
#1038 : 01背包 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励 ...
- hihoCoder week6 01背包
01背包 题目链接 https://hihocoder.com/contest/hiho6/problem/1 #include <bits/stdc++.h> using namespa ...
- C++ 实现01背包动态规划
简述一下01背包: 背包容量大小固定,有一些物品,每个物品都有重量和价值两个属性,且物品唯一不重复(即同一物品只能放入一个),放入物品的总重量不能超过背包容量 ,求放入背包的物品的总价值最大化.0代表 ...
- 【hihocoder】01背包
描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励的时刻了! 小Ho现在手上有M张奖券,而奖品区有N件奖品,分别标号为1到N,其中第i件奖品需要ne ...
- 【HIHOCODER 1038】 01背包
链接 问题描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励的时刻了! 小Ho现在手上有M张奖券,而奖品区有N件奖品,分别标号为1到N,其中第i件奖 ...
- Codeforces 2016 ACM Amman Collegiate Programming Contest A. Coins(动态规划/01背包变形)
传送门 Description Hasan and Bahosain want to buy a new video game, they want to share the expenses. Ha ...
- [C++] 动态规划之矩阵连乘、最长公共子序列、最大子段和、最长单调递增子序列、0-1背包
一.动态规划的基本思想 动态规划算法通常用于求解具有某种最优性质的问题.在这类问题中,可能会有许多可行解.每一个解都对应于一个值,我们希望找到具有最优值的解. 将待求解问题分解成若干个子问题,先求解子 ...
随机推荐
- Python实现常用排序算法
Python实现常用排序算法 冒泡排序 思路: 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完 ...
- The King’s Problem HDU - 3861(连通图 缩点 匹配)
在一个王国里面, 国王有一个新的问题. 皇城中有N个城市M条单行路,为了让他的王国更加高效,国王想要将他的王国划分成几个州,每个城市必须属于一个州.对于两个城市(u,v),必须满足以下3个条件: ...
- MSSQL-最佳实践-Always Encrypted
摘要 在SQL Server安全系列专题月报分享中,往期我们已经陆续分享了:如何使用对称密钥实现SQL Server列加密技术.使用非对称密钥实现SQL Server列加密.使用混合密钥实现SQL S ...
- [File transfer]Syncthing
https://syncthing.net/ 另外两种1.filezila 2.python -m http
- Flask框架(1)--基础
Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后 ...
- python学习day22 面向对象(四) 约束&反射
1.栈与队列 栈:类似弹夹,先进后出 队列:类似水管,先进先出 class Stack(object): """ 先进后出 """ def ...
- MVN TEST指定运行脚本
clean:表示将你上一次编译生成的一些文件删除 test:表示只执行测试代码 >mvn clean test -Dtest=[ClassName] 运行测试类中指定的方法:这个需要maven- ...
- linux下的/dev/shm/ 以及与swap目录的区别【转】
/dev/shm 概念 首先可以看出来/dev/shm是一个设备文件, 可以把/dev/shm看作是系统内存的入口, 可以把它看做是一块物理存储设备,一个tmp filesystem, 你可以通过这个 ...
- 一次对JDK进行"减肥"的记录
起因 最近做的一个小项目,因为要涉及到批量部署,每次在部署之前都需要在各个主机上先安装jdk环境(为了使用jdk自带的工具如jps等,所以没有单纯安装jre),但是因为jdk文件太大(以jdk-8u1 ...
- @JoinColumn解释
@JoinColumn与@Column标记一样,是用于注释表中的字段的.它的属性与@Column属性有很多相同之处,这里就不详细讲述.请读者参阅5.2.2小节中有关@Column属性的部分. l ...