转载请注明出处: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 多重背包(模板)的更多相关文章

  1. 背包问题(01背包,完全背包,多重背包(朴素算法&&二进制优化))

    写在前面:我是一只蒟蒻~~~ 今天我们要讲讲动态规划中~~最最最最最~~~~简单~~的背包问题 1. 首先,我们先介绍一下  01背包 大家先看一下这道01背包的问题  题目  有m件物品和一个容量为 ...

  2. Poj 1276 Cash Machine 多重背包

    Cash Machine Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 26172   Accepted: 9238 Des ...

  3. DP大作战——多重背包

    题目描述 在之前的上机中,零崎已经出过了01背包和完全背包,也介绍了使用-1初始化容量限定背包必须装满这种小技巧,接下来的背包问题相对有些难度,可以说是01背包和完全背包的进阶问题. 多重背包:物品可 ...

  4. hdu 2191 珍惜现在,感恩生活 多重背包入门题

    背包九讲下载CSDN 背包九讲内容 多重背包: hdu 2191 珍惜现在,感恩生活 多重背包入门题 使用将多重背包转化为完全背包与01背包求解: 对于w*num>= V这时就是完全背包,完全背 ...

  5. 多重背包转化成完全背包 E - Charlie's Change

    http://poj.org/problem?id=1787 这个题目我一看就觉得是一个多重背包,但是呢,我不知道怎么输出路径,所以无可奈何,我就只能看一下题解了. 看了题解发现居然是把多重背包转化成 ...

  6. (多重背包+记录路径)Charlie's Change (poj 1787)

    http://poj.org/problem?id=1787   描述 Charlie is a driver of Advanced Cargo Movement, Ltd. Charlie dri ...

  7. $POJ1742\ Coins$ 多重背包+贪心

    Vjudge传送门 $Sol$ 首先发现这是一个多重背包,所以可以用多重背包的一般解法(直接拆分法,二进制拆分法...) 但事实是会TLE,只能另寻出路 本题仅关注“可行性”(面值能否拼成)而不是“最 ...

  8. HDU 2844 Coins 【多重背包】(模板)

    <题目连接> 题目大意: 一位同学想要买手表,他有n种硬币,每种硬币已知有num[i]个.已知手表的价钱最多m元,问她用这些钱能够凑出多少种价格来买手表. 解题分析: 很明显,这是一道多重 ...

  9. hdu2844Coins(多重背包模板)

    Coins Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

随机推荐

  1. x264

    x264 x264  h264  1. x264调用主要过程 x264_param_default():设置参数集结构体x264_param_t的缺省值. x264_picture_alloc():为 ...

  2. TensorFlow学习---入门(一)-----MNIST机器学习

    参考教程:http://www.tensorfly.cn/tfdoc/tutorials/mnist_beginners.html 数据下载地址:http://wiki.jikexueyuan.com ...

  3. 如何将工程推到github上

    首先,读一下这个 Git-Pro中文版 步骤: 在本地文件系统中 git init 在github中新建项目(光新建就行了) 然后,出现下面这张图,打开sourceTree,按照上面的操作进行就行了. ...

  4. Codeforces_The least round way

    B. The least round way time limit per test 2 seconds memory limit per test 64 megabytes input standa ...

  5. 扩增子图表解读6韦恩图:比较组间共有和特有OTU或分类单元

    韦恩图 Venn Diagram Venn Diagram,也称韦恩图.维恩图.文氏图,用于显示元素集合重叠区域的图示.   韦图绘制工具 常用R语言的VennDiagram包绘制,输出PDF格式方便 ...

  6. PHP 之微信JSSDK类封装

    <?php class JSSDK { private $appId; private $appSecret; public function __construct($appId, $appS ...

  7. Springboot使用JdbcTemplate RowMapper查询,直接返回实体列表

    ManagerRowMapper.java public class ManagerRowMapper implements RowMapper<Manager>{ @Override p ...

  8. session_start(): open(/var/lib/php/session/sess_tlrp3cpro7gun9uhno8n6futr3, O_RDWR)

    在安装一个网站,结果连接上数据库了但是一直报错.下面贴报错内容和图 错误提示 系统:PHP (Linux) 错误类型:WARNING 内容:session_start(): open(/) 错误位置: ...

  9. vue 打印 页面特定部分转pdf

    https://www.jb51.net/article/147040.htm https://www.jianshu.com/p/dd120b65446a  //转pdf

  10. 小程序map地图多点定位

    最近需求有一个类似共享单车查看附近单车的功能,看了看小程序map api对多点定位显示描述的不怎么清晰.显示定位数组添加多个时就不显示了.踩了几个坑写了几个方法.最终弄出来了.有问题建议欢迎留言. h ...