背包DP入门小笔记01背包
FJUT OJ 2347 http://59.77.139.92/Problem.jsp?pid=2347
采药
辰辰是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师。为此,他想拜附近最有威望的医师为师。医师为了判断他的资质,给他出了一个难题。医师把他带到一个到处都是草药的山洞里对他说:“孩子,这个山洞里有一些不同的草药,采每一株都需要一些时间,每一株也有它自身的价值。我会给你一段时间,在这段时间里,你可以采到一些草药。如果你是一个聪明的孩子,你应该可以让采到的草药的总价值最大。”
如果你是辰辰,你能完成这个任务吗?
输入文件medic.in的第一行有两个整数T(1 <= T <= 1000)和M(1 <= M <= 100),用一个空格隔开,T代表总共能够用来采药的时间,M代表山洞里的草药的数目。接下来的M行每行包括两个在1到100之间(包括1和100)的整数,分别表示采摘某株草药的时间和这株草药的价值。
输出文件medic.out包括一行,这一行只包含一个整数,表示在规定的时间内,可以采到的草药的最大总价值。
70 3
71 100
69 1
1 2
3 Hint:对于30%的数据,M <= 10;
对于全部的数据,M <= 100。
答案1:

答案2:

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <queue> using namespace std;
const int maxn = ;
int dp[maxn][maxn],ti[maxn],value[maxn],t,m; void show()
{
/**
7 3
8 100
6 1
1 2
*/
for(int i=;i<=m;i++)
{
for(int j=;j<=t;j++)
printf("%2d",dp[i][j]);
puts("");
}
puts("-----------------------------");
} int main()
{
while(~scanf("%d%d",&t,&m))
{
memset(dp,,sizeof(dp));
memset(ti,,sizeof(ti));
memset(value,,sizeof(value));
for(int i=;i<=m;i++)
{
scanf("%d%d",&ti[i],&value[i]);
}
for(int i=; i<=m; i++)
{
for(int j=; j<=t; j++)
{
if(j>=ti[i])dp[i][j]=max(dp[i-][j],dp[i-][j-ti[i]]+value[i]);
else dp[i][j]=dp[i-][j];
show();
}
}
int maxx=;
for(int i=;i<=t;i++)
{
maxx=max(maxx,dp[m][i]);
}
printf("%d\n",maxx);
} return ;
}
DP[I][J]表示第I件物品放入,获得的最大价值。第一组案例放不下,从第二个开始,背包容量6以下都是0,一共6+7=13个矩阵是0,第14个矩阵开始,数组数字如下
   
压缩了状态,背包逆着放物品
#include <bits/stdc++.h>
#define N 20005 using namespace std;
int dp[N];
int i,j,T,m,ans,t,w; void show()
{
/**
7 3
8 100
6 1
1 2
*/
for(int i=;i<=T;i++)
{
printf("%-2d",dp[i]);
}
puts("");
}
int main()
{
scanf("%d%d",&T,&m);
while(m--)
{
scanf("%d%d",&t,&w);
for(j=T;j>=t;j--)
{
dp[j]=max(dp[j],dp[j-t]+w);
show();
}
puts("\n--------------------------");
}
ans=;
for(i=;i<=T;i++)
ans=max(ans,dp[i]);
printf("%d\n",ans);
return ;
}

背包DP入门小笔记01背包的更多相关文章
- vijos1059 积木城堡[n年浙江省队第X轮](背包的方案总数 or 01背包)
		
描述 XC的儿子小XC最喜欢玩的游戏用积木垒漂亮的城堡.城堡是用一些立方体的积木垒成的,城堡的每一层是一块积木.小XC是一个比他爸爸XC还聪明的孩子,他发现垒城堡的时候,如果下面的积木比上面的积木大, ...
 - HDU 1011 Starship Troopers【树形DP/有依赖的01背包】
		
You, the leader of Starship Troopers, are sent to destroy a base of the bugs. The base is built unde ...
 - nyoj49 开心的小明 01背包
		
思路:dp(i, j)表示用金钱j去买前i个物品能得到的最大价值.转移方程dp(i, j) = max{dp(i-1, j), dp(i-1, j-p[i]) + p[i]*w[i]}. AC代码 # ...
 - Re0:DP学习之路 01背包如何打印路径?
		
伪代码 用二维数组记录,如果出现可以转移的dp那么记录bk[当前体积][装的物品]=1 输出的时候倒推,如果存在连通的边那么输出并且总共的体积减去输出的体积 代码(uva-624,目前wa不明所以,网 ...
 - css通用小笔记01——导航背景
		
很多刚接触前端的可能遇到一些css能解决的小问题,我现在总结了一些,将会逐渐和大家分享,先是导航的背景问题,在网页中常常看到,当鼠标放到一个导航按钮上面是,就会出现一些特效,比如背景,这是最常用的,我 ...
 - Java_IO异常处理方式_入门小笔记
		
package IO; import java.io.FileWriter; import java.io.IOException; /** * IO异常处理方式 */ class FileWrite ...
 - poj 2184(dp变形,进一步加深01背包)
		
点击打开链接 题意: 给你n个物品,每个物品都有两个属性,s和f,要求选择一些物品,使sum(s)+sum(f)最大,并且sum(s)>=0&&sum(f)>=0, 根据0 ...
 - PKU--3628 Bookshelf 2(01背包)
		
题目http://poj.org/problem?id=3628 分析:给定一堆牛的高度,把牛叠加起来的高度超过牛棚的高度. 且是牛叠加的高度与牛棚高度之差最小. 把牛叠加的高度看作是背包的容量,利用 ...
 - 背包问题(01背包,完全背包,多重背包(朴素算法&&二进制优化))
		
写在前面:我是一只蒟蒻~~~ 今天我们要讲讲动态规划中~~最最最最最~~~~简单~~的背包问题 1. 首先,我们先介绍一下 01背包 大家先看一下这道01背包的问题 题目 有m件物品和一个容量为 ...
 
随机推荐
- mongodb 索引的基本命令
			
mongodb的索引: 在数据量超大的时候,能够极大的增快查询速率,但是会降低更新效率.建立索引: db.集合.ensureIndex({属性:1}) //1代表升序 -1代表降序 db.集合.ens ...
 - php程序报错:PHP Core Warning/cannot open shared object file: No such file or directory
			
今天开发调试程序的时候报错了,现象是有时候刷新会出现如下图: 这种主要是找不到共享库文件,即.so文件,网上主要有3种解决方法: 1. 用ln将需要的so文件链接到/usr/lib或者/lib这两个默 ...
 - 如何用elementui去实现图片上传和表单提交,用axios的post方法
			
下面是在vue搭建的脚手架项目中的组件component文件夹下面的upload.vue文件中的内容 <!--这个组件主要用来研究upload这个elementui的上传插件组件--> & ...
 - ansible批量加用户
			
ansible批量加用户 1.生成密码 pip install passlib python -c "from passlib.hash import sha512_crypt; print ...
 - python 函数“四剑客”的使用和介绍
			
python函数四剑客:lambda.map.filter和reduce. 一.lambda(匿名函数) 1. 学习lambda要注意一下几点: lambda语句被用来创建新的函数对象,并且在运行的时 ...
 - CodeForces 918D MADMAX(博弈+记忆化搜索)
			
time limit per test 1 second memory limit per test 256 megabytes input standard input output standar ...
 - openfire彻底卸载的方法
			
最近百度找openfire彻底卸载的方法,很多都是三句命令行的答案.但是那三句真的无法完全卸载 终于从openfire官网找到了卸载的命令 终端执行下面的命令 sudo rm -rf /usr/loc ...
 - Mysql单表查询(胖胖老师)
			
数据准备drop table if exists class;create table class( class_no int(2) unsigned zerofill primary key ...
 - [HNOI2011]数矩形
			
题目描述 最近某歌手在研究自己的全球巡回演出计划,他将所有心仪的城市都用平面上的一个点来表示,并打算从中挑选出 4 个城市作为这次巡回演出的地点. 为了显示自己与众不同,他要求存在一个矩形使得挑选出的 ...
 - [SDOI2008]烧水问题
			
题目描述 把总质量为1kg的水分装在n个杯子里,每杯水的质量均为(1/n)kg,初始温度均为0℃.现需要把每一杯水都烧开.我们可以对任意一杯水进行加热.把一杯水的温度升高t℃所需的能量为(4200*t ...