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 ...
随机推荐
- 6.11---字节输入流数据根据字节输出流存到文件中---io流概念及分类---文件存储的原理和记事本打开的原理---字节流读取文件的原理---文件复制的原理
- AOP注解不起作用的debug结果
经过2天的调试,我发现AOP注解配置不起作用居然是表达式的错误导致的 在xml文件中配置的base-package有关,初步认为@PointCut只能使用base-package..*(..)这样的方 ...
- [Codeforces]Codeforces Round #489 (Div. 2)
Nastya and an Array 输出有几种不同的数字 #pragma comment(linker, "/STACK:102400000,102400000") #ifnd ...
- 【sqli-labs】 less58 GET -Challenge -Double Query -5 queries allowed -Variation1 (GET型 挑战 双查询 只允许5次查询 变化1)
单引号闭合成功,但是union select结果不对 http://192.168.136.128/sqli-labs-master/Less-58/?id=0' union select 1,2,3 ...
- C# 把时间 月 //把第一个0替换为空
string str = "2019-01"; //name: "2019-01月" str = str.Substring(str.Length - , ); ...
- 非常好用的1款UI自动化测试工具:airTest
网易团队开发的UI自动化测试神器airTest,下载地址:http://airtest.netease.com/tutorial/Tutorial.html Appium和airTest对比,我的看法 ...
- js的一些老司机写法
//取整 parseInt(a,10); //Before Math.floor(a); //Before a>>0; //Before ~~a; //After a|0; //After ...
- CPU指令、机器码、程序和汇编语言
一.指令 指令就是指挥机器工作的指示和命令.控制器靠指令指挥机器工作,人们用指令表达自己的意图,并交给控制器执行.一台计算机所能执行的各种不同指令的全体,叫做计算机的指令系统或指令集,每一台计算机均有 ...
- EF-调用sql进行操作
一丶执行 class Program { static void Main(string[] args) { var db = new TestDBEntities(); string sql = @ ...
- TensorFlow 学习笔记(1)----线性回归(linear regression)的TensorFlow实现
此系列将会每日持续更新,欢迎关注 线性回归(linear regression)的TensorFlow实现 #这里是基于python 3.7版本的TensorFlow TensorFlow是一个机器学 ...