转载请注明出处:http://blog.csdn.net/u012860063

贴一个自觉得解说不错的链接:http://www.cppblog.com/tanky-woo/archive/2010/07/31/121803.html

模版就直接贴代码:

01背包模板:

  1. /*
  2. 01背包问题
  3. 01背包问题的特点是,">每种物品仅有一件。能够选择放或不放。
  4.  
  5. 01背包问题描写叙述:
  6. 有N件物品和一个容量为V的背包。
  7.  
  8. 第i件物品的重量是c[i],价值是w[i]。
  9.  
  10. 求解将哪些物品装入背包可使这些物品的重量总和不超过背包容量,且价值总和最大。
  11. */
  12. #include <stdio.h>
  13. #define N 1050017
  14. int max(int x,int y)
  15. {
  16. int M;
  17. M=x>y ?
  18.  
  19. x : y;
  20. return M;
  21. }
  22. int wei[N],val[N],f[N];
  23. int main()
  24. {
  25. int i, j, n, m;
  26. while(scanf("%d",&n)!=EOF)
  27. {
  28. scanf("%d", &m);
  29. for(i=0; i<n; i++)
  30. scanf("%d%d", &wei[i],&val[i]);//wei[i]为重量,val[i]为价值
  31. for(i=0; i<n; i++)
  32. {
  33. for(j=m; j>=wei[i]; j--)
  34. f[j] = max(f[j], f[j-wei[i]]+val[i]);
  35. }
  36. printf("%d\n",f[m]);
  37. }
  38. return 0;
  39. }
  40.  
  41. //此代码为poj3624

全然背包模板:

  1. /*
  2. 全然背包问题的特点是,每种物品能够无限制的反复使用。能够选择放或不放。
  3. 全然背包问题描写叙述:
  4. 有N物品和一个容量为V的背包。第i件物品的重量是wei[i],价值是val[i]。
  5. */
  6.  
  7. #include <cstdio>
  8. #define INF 0x3fffffff
  9. #define N 10047
  10. int f[N],val[N],wei[N];
  11. int min(int a,int b)
  12. {
  13. if(a < b)
  14. return a;
  15. return b;
  16. }
  17. int main()
  18. {
  19. int t,i,j,k,E,F,m,n;
  20. scanf("%d",&t);
  21. while(t--)
  22. {
  23. scanf("%d%d",&E,&F);
  24. int c = F-E;
  25. for(i = 0 ; i <= c ; i++)
  26. f[i]=INF;
  27. scanf("%d",&n);
  28. for(i = 0 ; i < n ; i++)
  29. {
  30. scanf("%d%d",&val[i],&wei[i]);//val[i]为面额。wei[i]为重量
  31. }
  32. f[0]=0;//由于此处如果的是小猪储钱罐 恰好装满 的情况
  33. //注意初始化(要求恰好装满背包,那么在初始化时除了f[0]为0其他f[1..V]均设为-∞。
  34. //这样就能够保证终于得到的f[N]是一种恰好装满背包的最优解。
  35. //如果并没有要求必须把背包装满。而是仅仅希望价格尽量大,初始化时应该将f[0..V]所有设为0)
  36. for(i =0 ; i < n ; i++)
  37. {
  38. for(j = wei[i] ; j <= c ; j++)
  39. {
  40. f[j] = min(f[j],f[j-wei[i]]+val[i]);//此处求的是最坏的情况所以用min。确定最少的钱,当然最后就用max了。HEHE
  41. }
  42. }
  43. if(f[c] == INF)
  44. printf("This is impossible.\n");
  45. else
  46. printf("The minimum amount of money in the piggy-bank is %d.\n",f[c]);
  47. }
  48. return 0;
  49. }
  50. //此代码为HDU1114;

    f[w] 即为所求  

        初始化分两种情况:

        1、假设背包要求正好装满则初始化 f[0] = 0, f[1~w] = -INF;  

        2、假设不须要正好装满 f[0~v] = 0;

多重背包模板:

  1. //多重背包(MultiplePack): 有N种物品和一个容量为V的背包。
  2. //第i种物品最多有n[i]件可用,每件费用是c[i],价值是w[i]。
  3. //求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量,
  4. //且价值总和最大。
  5.  
  6. //HDU 2191
  7.  
  8. #include <cstdio>
  9. #include <cstring>
  10. #define N 247
  11. int max(int a,int b)
  12. {
  13. if(a > b)
  14. return a;
  15. else return b;
  16. }
  17. int main()
  18. {
  19. int t,n,m,i,j,k;
  20. int w[N],pri[N],num[N],f[N];
  21. while(~scanf("%d",&t))
  22. {
  23. while(t--)
  24. {
  25. memset(f,0,sizeof(f));
  26. scanf("%d%d",&n,&m);//n为总金额,m为大米种类
  27. for(i = 0 ; i < m ; i++)
  28. {
  29. scanf("%d%d%d",&pri[i],&w[i],&num[i]);//num[i]为每种大米的袋数
  30. }
  31. for(i = 0 ; i < m ; i++)
  32. {
  33. for(k = 0 ; k < num[i] ; k++)
  34. {
  35. for(j = n ; j >= pri[i]; j--)
  36. {
  37. f[j] = max(f[j],f[j-pri[i]]+w[i]);
  38. }
  39. }
  40. }
  41. printf("%d\n",f[n]);
  42. }
  43. }
  44. return 0;
  45. }

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. 6.11---字节输入流数据根据字节输出流存到文件中---io流概念及分类---文件存储的原理和记事本打开的原理---字节流读取文件的原理---文件复制的原理

  2. AOP注解不起作用的debug结果

    经过2天的调试,我发现AOP注解配置不起作用居然是表达式的错误导致的 在xml文件中配置的base-package有关,初步认为@PointCut只能使用base-package..*(..)这样的方 ...

  3. [Codeforces]Codeforces Round #489 (Div. 2)

    Nastya and an Array 输出有几种不同的数字 #pragma comment(linker, "/STACK:102400000,102400000") #ifnd ...

  4. 【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 ...

  5. C# 把时间 月 //把第一个0替换为空

    string str = "2019-01"; //name: "2019-01月" str = str.Substring(str.Length - , ); ...

  6. 非常好用的1款UI自动化测试工具:airTest

    网易团队开发的UI自动化测试神器airTest,下载地址:http://airtest.netease.com/tutorial/Tutorial.html Appium和airTest对比,我的看法 ...

  7. js的一些老司机写法

    //取整 parseInt(a,10); //Before Math.floor(a); //Before a>>0; //Before ~~a; //After a|0; //After ...

  8. CPU指令、机器码、程序和汇编语言

    一.指令 指令就是指挥机器工作的指示和命令.控制器靠指令指挥机器工作,人们用指令表达自己的意图,并交给控制器执行.一台计算机所能执行的各种不同指令的全体,叫做计算机的指令系统或指令集,每一台计算机均有 ...

  9. EF-调用sql进行操作

    一丶执行 class Program { static void Main(string[] args) { var db = new TestDBEntities(); string sql = @ ...

  10. TensorFlow 学习笔记(1)----线性回归(linear regression)的TensorFlow实现

    此系列将会每日持续更新,欢迎关注 线性回归(linear regression)的TensorFlow实现 #这里是基于python 3.7版本的TensorFlow TensorFlow是一个机器学 ...