01背包模板、全然背包 and 多重背包(模板)
转载请注明出处:http://blog.csdn.net/u012860063
贴一个自觉得解说不错的链接:http://www.cppblog.com/tanky-woo/archive/2010/07/31/121803.html
模版就直接贴代码:
01背包模板:
/*
01背包问题
01背包问题的特点是,">每种物品仅有一件。能够选择放或不放。 01背包问题描写叙述:
有N件物品和一个容量为V的背包。 第i件物品的重量是c[i],价值是w[i]。 求解将哪些物品装入背包可使这些物品的重量总和不超过背包容量,且价值总和最大。
*/
#include <stdio.h>
#define N 1050017
int max(int x,int y)
{
int M;
M=x>y ? x : y;
return M;
}
int wei[N],val[N],f[N];
int main()
{
int i, j, n, m;
while(scanf("%d",&n)!=EOF)
{
scanf("%d", &m);
for(i=0; i<n; i++)
scanf("%d%d", &wei[i],&val[i]);//wei[i]为重量,val[i]为价值
for(i=0; i<n; i++)
{
for(j=m; j>=wei[i]; j--)
f[j] = max(f[j], f[j-wei[i]]+val[i]);
}
printf("%d\n",f[m]);
}
return 0;
} //此代码为poj3624
全然背包模板:
/*
全然背包问题的特点是,每种物品能够无限制的反复使用。能够选择放或不放。
全然背包问题描写叙述:
有N物品和一个容量为V的背包。第i件物品的重量是wei[i],价值是val[i]。
*/ #include <cstdio>
#define INF 0x3fffffff
#define N 10047
int f[N],val[N],wei[N];
int min(int a,int b)
{
if(a < b)
return a;
return b;
}
int main()
{
int t,i,j,k,E,F,m,n;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&E,&F);
int c = F-E;
for(i = 0 ; i <= c ; i++)
f[i]=INF;
scanf("%d",&n);
for(i = 0 ; i < n ; i++)
{
scanf("%d%d",&val[i],&wei[i]);//val[i]为面额。wei[i]为重量
}
f[0]=0;//由于此处如果的是小猪储钱罐 恰好装满 的情况
//注意初始化(要求恰好装满背包,那么在初始化时除了f[0]为0其他f[1..V]均设为-∞。
//这样就能够保证终于得到的f[N]是一种恰好装满背包的最优解。
//如果并没有要求必须把背包装满。而是仅仅希望价格尽量大,初始化时应该将f[0..V]所有设为0)
for(i =0 ; i < n ; i++)
{
for(j = wei[i] ; j <= c ; j++)
{
f[j] = min(f[j],f[j-wei[i]]+val[i]);//此处求的是最坏的情况所以用min。确定最少的钱,当然最后就用max了。HEHE
}
}
if(f[c] == INF)
printf("This is impossible.\n");
else
printf("The minimum amount of money in the piggy-bank is %d.\n",f[c]);
}
return 0;
}
//此代码为HDU1114;
f[w] 即为所求
初始化分两种情况:
1、假设背包要求正好装满则初始化 f[0] = 0, f[1~w] = -INF;
2、假设不须要正好装满 f[0~v] = 0;
多重背包模板:
//多重背包(MultiplePack): 有N种物品和一个容量为V的背包。
//第i种物品最多有n[i]件可用,每件费用是c[i],价值是w[i]。
//求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量,
//且价值总和最大。 //HDU 2191 #include <cstdio>
#include <cstring>
#define N 247
int max(int a,int b)
{
if(a > b)
return a;
else return b;
}
int main()
{
int t,n,m,i,j,k;
int w[N],pri[N],num[N],f[N];
while(~scanf("%d",&t))
{
while(t--)
{
memset(f,0,sizeof(f));
scanf("%d%d",&n,&m);//n为总金额,m为大米种类
for(i = 0 ; i < m ; i++)
{
scanf("%d%d%d",&pri[i],&w[i],&num[i]);//num[i]为每种大米的袋数
}
for(i = 0 ; i < m ; i++)
{
for(k = 0 ; k < num[i] ; k++)
{
for(j = n ; j >= pri[i]; j--)
{
f[j] = max(f[j],f[j-pri[i]]+w[i]);
}
}
}
printf("%d\n",f[n]);
}
}
return 0;
}
01背包模板、全然背包 and 多重背包(模板)的更多相关文章
- 背包问题(01背包,完全背包,多重背包(朴素算法&&二进制优化))
写在前面:我是一只蒟蒻~~~ 今天我们要讲讲动态规划中~~最最最最最~~~~简单~~的背包问题 1. 首先,我们先介绍一下 01背包 大家先看一下这道01背包的问题 题目 有m件物品和一个容量为 ...
- Poj 1276 Cash Machine 多重背包
Cash Machine Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 26172 Accepted: 9238 Des ...
- DP大作战——多重背包
题目描述 在之前的上机中,零崎已经出过了01背包和完全背包,也介绍了使用-1初始化容量限定背包必须装满这种小技巧,接下来的背包问题相对有些难度,可以说是01背包和完全背包的进阶问题. 多重背包:物品可 ...
- hdu 2191 珍惜现在,感恩生活 多重背包入门题
背包九讲下载CSDN 背包九讲内容 多重背包: hdu 2191 珍惜现在,感恩生活 多重背包入门题 使用将多重背包转化为完全背包与01背包求解: 对于w*num>= V这时就是完全背包,完全背 ...
- 多重背包转化成完全背包 E - Charlie's Change
http://poj.org/problem?id=1787 这个题目我一看就觉得是一个多重背包,但是呢,我不知道怎么输出路径,所以无可奈何,我就只能看一下题解了. 看了题解发现居然是把多重背包转化成 ...
- (多重背包+记录路径)Charlie's Change (poj 1787)
http://poj.org/problem?id=1787 描述 Charlie is a driver of Advanced Cargo Movement, Ltd. Charlie dri ...
- $POJ1742\ Coins$ 多重背包+贪心
Vjudge传送门 $Sol$ 首先发现这是一个多重背包,所以可以用多重背包的一般解法(直接拆分法,二进制拆分法...) 但事实是会TLE,只能另寻出路 本题仅关注“可行性”(面值能否拼成)而不是“最 ...
- HDU 2844 Coins 【多重背包】(模板)
<题目连接> 题目大意: 一位同学想要买手表,他有n种硬币,每种硬币已知有num[i]个.已知手表的价钱最多m元,问她用这些钱能够凑出多少种价格来买手表. 解题分析: 很明显,这是一道多重 ...
- hdu2844Coins(多重背包模板)
Coins Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
随机推荐
- x264
x264 x264 h264 1. x264调用主要过程 x264_param_default():设置参数集结构体x264_param_t的缺省值. x264_picture_alloc():为 ...
- TensorFlow学习---入门(一)-----MNIST机器学习
参考教程:http://www.tensorfly.cn/tfdoc/tutorials/mnist_beginners.html 数据下载地址:http://wiki.jikexueyuan.com ...
- 如何将工程推到github上
首先,读一下这个 Git-Pro中文版 步骤: 在本地文件系统中 git init 在github中新建项目(光新建就行了) 然后,出现下面这张图,打开sourceTree,按照上面的操作进行就行了. ...
- Codeforces_The least round way
B. The least round way time limit per test 2 seconds memory limit per test 64 megabytes input standa ...
- 扩增子图表解读6韦恩图:比较组间共有和特有OTU或分类单元
韦恩图 Venn Diagram Venn Diagram,也称韦恩图.维恩图.文氏图,用于显示元素集合重叠区域的图示. 韦图绘制工具 常用R语言的VennDiagram包绘制,输出PDF格式方便 ...
- PHP 之微信JSSDK类封装
<?php class JSSDK { private $appId; private $appSecret; public function __construct($appId, $appS ...
- Springboot使用JdbcTemplate RowMapper查询,直接返回实体列表
ManagerRowMapper.java public class ManagerRowMapper implements RowMapper<Manager>{ @Override p ...
- session_start(): open(/var/lib/php/session/sess_tlrp3cpro7gun9uhno8n6futr3, O_RDWR)
在安装一个网站,结果连接上数据库了但是一直报错.下面贴报错内容和图 错误提示 系统:PHP (Linux) 错误类型:WARNING 内容:session_start(): open(/) 错误位置: ...
- vue 打印 页面特定部分转pdf
https://www.jb51.net/article/147040.htm https://www.jianshu.com/p/dd120b65446a //转pdf
- 小程序map地图多点定位
最近需求有一个类似共享单车查看附近单车的功能,看了看小程序map api对多点定位显示描述的不怎么清晰.显示定位数组添加多个时就不显示了.踩了几个坑写了几个方法.最终弄出来了.有问题建议欢迎留言. h ...