原文链接http://www.cnblogs.com/zhouzhendong/p/8684027.html

题目传送门 - BZOJ2287

题意

  有$n$个物品,第$i$个物品的体积为$w_i$。

  令$cnt_{i,j}$表示不取第$i$个物品,占用$j$体积的方案总数。

  每一个物品只能取或者不取。

  让你对于每一个$i,j(1\leq i\leq n,1\leq j\leq m)$输出$cnt_{i,j}$。

  $n,m\leq 2\times 10^3$

题解

  这题有两种做法,时间复杂度不同,但是跑出来差不多,嘻嘻。

  $\Large Solution\ 1:$

  这个是经典的分治背包问题。第$i$个物品的出现时间为[1,i)U(i,n]。

  然后你会发现这个就是上一题BZOJ4025的弱化版。只是把并查集的一系列操作改成了$O(m)$背包DP而已。

  具体不再赘述,自行感受BZOJ4025的做法。

  时间复杂度$O(n^2\log n)$。

  $\Large Solution\ 2:$

  动态规划。

  首先处理出$f_n$表示没有任何限制搞01背包占用$n$体积的方案总数。

  考虑得到$cnt_{i,j}$。

  接下来分两种情况讨论。

  $j<w_i\Rightarrow cnt_{i,j}=f_j$:显然$f_j$的方案中不可能拿第$i$个物品啊。所以直接等于啊。

  $j\geq w_i\Rightarrow cnt_{i,j}=f_j-cnt_{i,j-w_i}$:考虑到$f_j$的方案中会有拿了第$i$个物品的情况,所以我们只要考虑减掉拿了第$i$个物品的情况。其他物品所占用的容量显然为$j-w_i$的。但是第$i$个物品只能拿一次啊,所以以后就不能拿了,所以是$cnt_{i,j-w_i}$。

  时间复杂度$O(n^2)$。

  然而,实际上跑出来差不多。

2679062 zhouzhendong 2287 Accepted 17008 kb 388 ms C++/Edit 610 B 2018-03-31 20:01:27
2679058 zhouzhendong 2287 Accepted 17004 kb 452 ms C++/Edit 942 B 2018-03-31 19:56:48

  下面的那个是分治的耗时,上面的那个是直接DP。

代码

分治

#include <bits/stdc++.h>
using namespace std;
const int N=2005;
vector <int> x,y;
int n,m,w[N],cnt[N][N];
void solve(int L,int R,vector <int> x,vector <int> &y){vector <int> z;z.clear();for (int i=0;i<y.size();i++){int id=y[i];if (L<=id&&id<=R){z.push_back(id);continue;}for (int j=m-w[id];j>=0;j--)x[j+w[id]]=(x[j+w[id]]+x[j])%10;}if (L==R){for (int i=0;i<=m;i++)cnt[L][i]=x[i];return;}int mid=(L+R)>>1;solve(L,mid,x,z);solve(mid+1,R,x,z);
}
int main(){scanf("%d%d",&n,&m);for (int i=1;i<=n;i++)scanf("%d",&w[i]);x.clear(),y.clear();x.push_back(1);for (int i=1;i<=m;i++)x.push_back(0);for (int i=1;i<=n;i++)y.push_back(i);solve(1,n,x,y);for (int i=1;i<=n;i++,puts(""))for (int j=1;j<=m;j++)printf("%d",cnt[i][j]);return 0;
}

  

DP

#include <bits/stdc++.h>
using namespace std;
const int N=2005;
int n,m,w[N],f[N],cnt[N][N];
int main(){scanf("%d%d",&n,&m);for (int i=1;i<=n;i++)scanf("%d",&w[i]);memset(f,0,sizeof f);f[0]=1;for (int i=1;i<=n;i++)for (int j=m-w[i];j>=0;j--)f[j+w[i]]=(f[j+w[i]]+f[j])%10;for (int i=1;i<=n;i++){for (int j=0;j<w[i];j++)cnt[i][j]=f[j];for (int j=w[i];j<=m;j++)cnt[i][j]=(f[j]-cnt[i][j-w[i]]+10)%10;}for (int i=1;i<=n;i++,puts(""))for (int j=1;j<=m;j++)printf("%d",cnt[i][j]);return 0;
}

  

转载于:https://www.cnblogs.com/zhouzhendong/p/BZOJ2287.html

BZOJ2287 【POJ Challenge】消失之物 动态规划 分治相关推荐

  1. BZOJ 2287 POJ Challenge 消失之物

    BZOJ题目不完整,看了看题解.发现他们都要取模10,还以为是dp的限制. 改了两小时,之后猛然发现.卧槽原本我少了一个取模. 写法1:暴力写法 最简单的想法(只要你会背包dp) 我在枚举每次不选哪个 ...

  2. bzoj2287【POJ Challenge】消失之物 缺一01背包

    bzoj2287[POJ Challenge]消失之物 缺一01背包 链接 bzoj 思路 分治solve(l,r,arr)表示缺少物品\([l,r]\)的dp数组arr. 然后solve(l,mid ...

  3. 2287. 【POJ Challenge】消失之物(数组递推\分治优化背包)

    2287. [POJ Challenge]消失之物 这题的思想和P4564 [CTSC2018]假面优化的思想一样,应该反过来说,假面那个题应该是借鉴这题的思路. 显然不能枚举每个物品消失O(n)O( ...

  4. BZOJ 2287 【POJ Challenge】消失之物

    2287: [POJ Challenge]消失之物 Description ftiasch 有 N 个物品, 体积分别是 W1, W2, ..., WN. 由于她的疏忽, 第 i 个物品丢失了. &q ...

  5. bzoj2295【POJ Challenge】我爱你啊*

    bzoj2295[POJ Challenge]我爱你啊 题意: 求一个字符串中有多少个"luvletter"(不包括引号).字符串长度≤100000. 题解: 连kmp都不用-- ...

  6. 2287: 【POJ Challenge】消失之物

    Description ftiasch 有 N 个物品, 体积分别是 W1, W2, ..., WN. 由于她的疏忽, 第 i 个物品丢失了. "要使用剩下的 N - 1 物品装满容积为 x ...

  7. 【数据结构与算法】【算法思想】【联系与区别】回溯 贪心 动态规划 分治

    4种算法思想比较与联系 如果将贪心,分治,回溯和动态规划四种算法思想分类,那贪心,回溯,动态规划可归为一类,而分治单独可以作为一类,因为它跟其他是三个都不大一样. 因为前三个算法解决问题的模型,都可以 ...

  8. 蓝桥杯:试题 算法训练 采油区域 矩阵前缀和+动态规划+分治+枚举

    资源限制 时间限制:2.0s 内存限制:512.0MB 采油区域 Siruseri政府决定将石油资源丰富的Navalur省的土地拍卖给私人承包商以建立油井.被拍卖的整块土地为一个矩形区域,被划分为M× ...

  9. 牛客网练习赛7--购物 动态规划

    题意: 在遥远的东方,有一家糖果专卖店. 这家糖果店将会在每天出售一些糖果,它每天都会生产出m个糖果,第i天的第j个糖果价格为C[i][j]元. 现在的你想要在接下来的n天去糖果店进行选购,你每天可以 ...

  10. POJ 2336 Ferry Loading II 动态规划

    题意:一个渡河问题,船每次最多可以载n辆车,单程渡河的时间是t,有m辆车要渡河,问最少时间把所有车运过河去的时间是多少,这个情况下,最少的运输次数是多少. 分析:确实是动态规划,惭愧我想了很久,也没想 ...

最新文章

  1. CATransform3DRotate 实现左右,上下翻转效果
  2. 蓝桥杯-答疑-java
  3. php生成二维码并返回给前端页面显示
  4. Python学习教程(Python学习路线):Python3之递归函数简单示例
  5. Spark RDD的默认分区数:(spark 2.1.0)
  6. ConcurrentHashMap的源码分析-fullAddCount源码分析
  7. java语言转换c语言,求助大神!!!JAVA转换成C语言
  8. 故宫也在拼多多卖货!故宫文具将入驻拼多多开设旗舰店!
  9. git 删除和复制远程分支
  10. VOC标签转化为YOLO标签
  11. 面向对象(二) 继承/里氏替换
  12. python activiti bpmn_Activiti 用户指南(BPMN 2.0介绍)
  13. leetCode题解之寻找string中最后一个word的长度
  14. matlab没有曲线,有个程序,运行后只有坐标没有曲线,是怎么回事呢 望大神们解答...
  15. 数字化工厂建设方案探讨
  16. 科普:什么是CPU?CPU和芯片关系?CPU怎么做的?CPU有什么用?不同CPU有什么区别?我们怎么选CPU?(待补充完整)
  17. 程序猿杂记——七年之痒
  18. 为什么要阅读——兼分享《首先,打破一切常规》[中译文]:世界顶级管理者的成功秘诀/(美)马库斯#183;白金汉,(美)柯特#183;科夫曼 著...
  19. 研发思维08----嵌入式智能产品数据服务后端分析
  20. 高级软件工程第九次作业:东理三剑客团队作业-随笔6

热门文章

  1. NetDevOps常用数据库安装与基本操作--SQL数据库
  2. Linux中如何针对用户及组设置磁盘配额
  3. webstorm开发微信小程序
  4. CSUOJ 1111 三家人
  5. tomcat内存设置
  6. 如何获取系统Home(Launcher)应用判断用户是否处于home界面
  7. 微信开发(1) -- 将本地开发环境映射到公网访问
  8. [svn] 在线安装
  9. 编程大讲坛 坛坛是佳酿--编程大讲坛:C语言核心开发技术从入门到精通
  10. Spring后端接收表单方式上传的文件和数据