转载请注明出处: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. java定时器和实时查询数据库

    定时器: Timer timer = new Timer();                    timer.schedule(new TimerTask() {                  ...

  2. OFDM同步算法之Schmidl算法

    Schmidl算法代码 算法原理 训练序列结构 T=[A A],其中A表示复伪随机序列PN,进行N/2点ifft变换得到的符号序列 \[M(d)=\frac{\left | P(d) \right | ...

  3. Android 升级安装APK兼容Android7.0,解决FileUriExposedException

    我们在开发app时避免不了需要添加应用内升级功能.当app启动时,如果检测到最新版本,将apk安装包从服务器下载下来,执行安装.安装apk的代码一般写法如下,网上随处可以搜到 public stati ...

  4. Centos安装smokeping教程

    Centos安装smokeping教程 一 .安装基本依赖包 ntpdate time.windows.com #64bit rpm -Uhv http://apt.sw.be/redhat/el6/ ...

  5. php 在不知道字符串有多长的情况下,如何去除前三个字符?

    $string='字符串';$subject=substr_replace(string,'',0,3);

  6. Unity中确定时间是否在一定范围内

    NowTime = DateTime.Now.ToLocalTime(); Timeyear = DateTime.Now.ToLocalTime().ToString("yyyy-MM-d ...

  7. swift--Xcode7 使用Alamofire框架发送HTTP请求报错

    控制台打印的错误信息: Application Transport Security has blocked a cleartext HTTP (http://) resource load sinc ...

  8. 求n!(高精度问题)

    #include <iostream> #include <stdio.h> #define MAX 10000 using namespace std; void Mul(i ...

  9. (C/C++学习)6.数组指针和指针数组

    说明:int (*p)[4] 和 int *p[4](数组指针和指针数组),如果你是一个初学者,也许当你看到这两个名词的时候,已经懵了.其实,只要你理解了其中的含义.这两个名词对你来说会相当简单并且很 ...

  10. 使用Python的Flask框架,结合Highchart,动态渲染图表(Ajax 请求数据接口)

    参考链接:https://www.highcharts.com.cn/docs/ajax 参考链接中的示例代码是使用php写的,这里改用python写. 需要注意的地方: 1.接口返回的数据格式,这个 ...