解法(背包DP问题)

(下为转)

  1. 其实感觉 像此题这种类型的并不属于dp范畴
  2. 虽然程序看起来使用的是递推这一过程,但总不能说开个二重循环就是dp
  3. 如果只从求解上来讲(不考虑数据值的范围), 只有枚举这唯一途径, 而此题的复杂度为O(20^20), 大约等于 10^26, 微机是很难在短时间内求解的。
  4. 而此题还有另一个限制, 就是数据值的范围, 虽然状态数那么多, 但是它们的范围有限这个时候, 状态产生大量重复, 于是, 程序可以优化为压缩这些重复状态, 从而减少开销
  5. 在实现的过程中, 确实划分了阶段, 但这个过程更像是枚举, 优化过后的枚举
  6. 在朴素枚举当中, 阶段数与复杂度呈指数关系, 而在此题这种特殊情况下, 每个阶段数的最大不同状态数是有限的, 压缩以后就只是常数关系了
  7. 所以那 'dp'方程更像是一个'压缩状态'过程, 并没有求最优这一意思, 最后输出是状态数, 并不是最优解
  8. 再看一些常见的dp问题, 它们的意义很明确, 一定是求某种最优的结果, 其中普遍存在max,min
  9. 最为关键的一点, 凡是能够被dp的问题, 都是p类问题, 它们的复杂度都为多项式表达式
  10. 而该题类似的问题, 它们似乎往往都是npc问题, 它们很难有特别有效的算法
  11. 像本题这种就是通过狭小的数据范围来进行优化, 但仍然逃不脱枚举这一本质,
  12. 如果稍微加大数据范围, 您看看还有更好的方法么?

这道题目是按照平衡度来考虑的,即挂完砝码后整个天平的值,从而可以划分为逐次挂砝码的阶段,则此次挂砝码和上一次的过程就存在了重叠子问题。运用DP就可以

有效的减少状态数。

我们使用DP[i][j]表示挂第i个砝码时平衡度为j的状态数。显然i的范围是1-20,对j来说,砝码重量是1-25,且不同砝码重量两两不同,而挂钩的范围是-15-+15,最多有20个砝码,故取值范围为(5+6+...+25)*15,即-4500~+4500,由此可以确定需要开出的table大小。

代码如下:

  1. #include<iostream>
  2. using namespace std;
  3. int hook[];
  4. int weight[];
  5. int balance[][];
  6.  
  7. int main()
  8. {
  9. int hC,wG,i,j,k,value;
  10. cin>>hC>>wG;
  11. memset(balance,,sizeof(balance));
  12. for(i=;i<hC;i++)
  13. {
  14. cin>>hook[i];
  15. }
  16. for(i=;i<wG;i++)
  17. {
  18. cin>>weight[i];
  19. }
  20. for(i=;i<hC;i++)
  21. {
  22. balance[][weight[]*hook[i]+]++;
  23. }
  24. for(i=;i<wG;i++)
  25. {
  26. for(j=;j<;j++)
  27. {
  28. if(balance[i-][j]!=)
  29. {
  30. for(k=;k<hC;k++)
  31. {
  32. value=weight[i]*hook[k];
  33. balance[i][j+value]+=balance[i-][j];
  34. }
  35. }
  36. }
  37. }
  38. cout<<balance[wG-][+]<<endl;
  39. return ;
  40. }

这种方法的复杂度为 O(C*G*9000)

poj1837挂砝码的更多相关文章

  1. POJ 1837 Balance 【DP】

    题意:给出一个天平,给出c个钩子,及c个钩子的位置pos[i],给出g个砝码,g个砝码的质量w[i],问当挂上所有的砝码的时候,使得天平平衡的方案数, 用dp[i][j]表示挂了前i个砝码时,平衡点为 ...

  2. POJ 1837 Balance 01背包

    题目: http://poj.org/problem?id=1837 感觉dp的题目都很难做,这道题如果不看题解不知道憋到毕业能不能做出来,转化成了01背包问题,很神奇.. #include < ...

  3. Uva 1354 Mobile Computing

    题目链接 题意: 在一个宽为r 的房间里, 有s个砝码, 每个天平的一端要么挂砝码, 要么挂另一个天平, 并且每个天平要保持平衡. 求使得所有砝码都放在天平上, 且总宽度不超过房间宽度的最大值. 思路 ...

  4. poj 1837 01背包

    Balance Time Limit: 1000 MS Memory Limit: 30000 KB 64-bit integer IO format: %I64d , %I64u Java clas ...

  5. POJ1837 Balance[分组背包]

    Balance Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 13717   Accepted: 8616 Descript ...

  6. dp之二维背包poj1837(天平问题 推荐)

    题意:给你c(2<=c<=20)个挂钩,g(2<=g<=20)个砝码,求在将所有砝码(砝码重1~~25)挂到天平(天平长  -15~~15)上,并使得天平平衡的方法数..... ...

  7. 【个人训练】(POJ1837)Balance

    这几天抓住国庆的黄金时间(因为没有女朋友,天天刷题emmmm 其实还在肝少前还要捞秋刀鱼) ,重点攻克掉几个基本的地方:搜索.dp.图论.这几天的题目应该就是这些范围. 题意 原题的意思大概是这样的, ...

  8. poj1837

    Balance Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 12995   Accepted: 8142 Descript ...

  9. POJ1837 Balance 背包

    题目大意: 有一个天平,天平左右两边各有若干个钩子,总共有C个钩子(每个钩子有相对于中心的距离,左负右正),有G个钩码,求将钩码全部挂到钩子上使天平平衡的方法的总数. 将每个砝码看作一组,组内各个物品 ...

随机推荐

  1. 教你Ant安装和配置

    Ant它是基于Java施工工具,它的主要作用是产生能够运行Java计划,把握Ant一些功能可以使项目更专业. 忙乱,可以在这里下载2014年8最近一个月Ant http://download.csdn ...

  2. SQL字符串转换为数组

    /*一.按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果. -----rtrim(@str)去掉 @str右边的字符 ltrim(@ ...

  3. crawler_httpurlconnection_自动编码识别

    核心思想: 1:从响应头中读取 [命中解流准确率最高] 2:如果响应头中没有,打开流从源码中读取,[取舍,如果有一般在前30行会有,前100行中寻找] 3:如果还没有,根据字节码code位置,字符识别 ...

  4. linux_shell_轮询触发启动脚本

    while [ 1 ]do length=`redis-cli -h *.*.*.* -p 8000 llen eq` while [ $length -gt 1 ] do echo "le ...

  5. DES加密深度优化——随机生成加密字符串

    DES全称为Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法.但该算法一旦密钥固定,加密的字符串也就随之固定,这不利于数据存储安全.而且用该方法加密后有一个 ...

  6. 如何利用百度音乐播放器的API接口来获取高音质歌曲

    第一步:在网页中打开以下网址: http://box.zhangmen.baidu.com/x?op=12&count=1&title=时间都去哪儿了$$王铮亮$$$$ 其中红色地方可 ...

  7. ZOJ 3802 Easy 2048 Again 像缩进DP

    链接:problemId=5334">http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5334 题意:一个长度为5 ...

  8. 基于.NET MVC的高性能IOC插件化架构

    基于.NET MVC的高性能IOC插件化架构 最近闲下来,整理了下最近写的代码,先写写架构,后面再分享几个我自己写的插件 最近经过反复对比,IOC框架选择了Autofac,原因很简单,性能出众,这篇博 ...

  9. C#中四个判等函数的认识

    donet提供了四个判等函数,分别是referenceEqual,静态Equal,具体类型Equal,和==. 首先来说,object.referenceEqual和静态Equal public st ...

  10. asp.net 操作XML

    using System.Xml; using System.Data; using System.IO;   string xmlpath = HttpRuntime.AppDomainAppPat ...