背包:

消失之物

先直接做一遍,必然对于i,有

for(j=m;j>=w[i];--j)

f[i]+=f[i-w[i]]

所以,如果排除用i做背包的结果,减去这个转移就好了。

memcpy(g,f,sizeof f)

for(j=w[i];j<=m;++j)

g[j]-=g[j-w[i]]

关于i的一行就都有了。

[POI2012]SZA-Cloakroom

又是一个有三个属性的题。

肯定要离线。询问关于m排序,物品按照a排序。

k比较小,n比较小。

f[i]表示,决策到当前这个a为止,凑成和为i的所有方案中,最小的b最大是多少。(为了保证bi>m+s)

这样,每到一个决策点m,就可以利用当前处理的f[k]>m+s即可判断能否实现。

因为保证的是最小的b最大是多少。正确性显然。

怎么处理的三个属性呢?a当做顺序,c当做状态,b当做数值。再加上离线对m排序。然后求最小的b最大是多少,直接把配凑问题转化成判定问题。

复杂度O(1e8)可过。

[HNOI2007]梦幻岛宝珠

bzoj1190 [HNOI2007]梦幻岛宝珠 ( 二进制分组优化背包DP)

分层DP。以b为层。

f[i][j]表示,小于等于j*2^i+(w&(1<<(i-1))的最大价值。

每层就是一个0/1背包。

然后考虑逐层合并出来真正的f[i][j]

从低位往高位合并。

f[i][j]=max(f[i][j],f[i][j-k]+f[i-1][min(1000,2*k+((w>>(i-1))&1)]

意义是:把j拆出来k位,用i-1两倍的k来凑出来,然后为了保证+(w&(1<<(i-1))这个东西,就要保证i-1必要时提供一个1*2^(i-1)

至于对1000取min,是可以的。因为本身就不可能达到,而本身就是一个前缀min,这样找不可能超出。

至于那一步加法也是可以的,f[i][j-k]还只是当前层的,就相当于把当前层取出来一些,再把低位的一些取出来拼凑。

至于f[i][j]弄出来前缀的特点,就不要把f[i][j]初值-inf即可。

具体代码见上面的博客(虽然有错)

树形dp

[SCOI2015]小凸玩密室

厉害的树形dp。

神奇的状态设计。

一些需要考虑的细节。

由于起点不定,所以,填法有两种:

1.填完这个子树后,点某个祖先。

2.填完这个子树后,点某个祖先的兄弟。

dp[i][j][0/1]表示,填完以i为根的子树,再取点第j个祖先/第j个祖先的兄弟的代价。

每个点只能在被点到的时候统计贡献,因为这样才能知道距离。nlogn

其实就是一个对未来的承诺。

因为我们不知道填完这个上一个是哪一个,就不能统计贡献。

所以,干脆,就在填完这个之后,直接枚举下一个是哪一个,然后就把贡献算上即可。真在那里填的话,贡献就已经算好了。

而且,祖先只有logn个,下一个填哪一个的方案数比较少。

然后要处理答案。

发现,当起点固定的话,必然要先点完整个子树,然后点父亲,点兄弟子树,再点爷爷,点叔叔子树。

所以,一路模拟即可。

处理答案的复杂度:nlogn

https://blog.chenqiqian.com/20180608-SCOI2015-room/

基础dp例题整理的更多相关文章

  1. 基础dp

    队友的建议,让我去学一学kuangbin的基础dp,在这里小小的整理总结一下吧. 首先我感觉自己还远远不够称为一个dp选手,一是这些题目还远不够,二是定义状态的经验不足.不过这些题目让我在一定程度上加 ...

  2. 基础DP(初级版)

    本文主要内容为基础DP,内容来源为<算法导论>,总结不易,转载请注明出处. 后续会更新出kuanbin关于基础DP的题目...... 动态规划: 动态规划用于子问题重叠的情况,即不同的子问 ...

  3. SVG.js 基础图形绘制整理(二)

    一.折线 var draw = SVG('svg1').size(300, 300); //画折线 //使用字符串点 // var polyline=draw.polyline('0,0 100,50 ...

  4. hdu 5586 Sum 基础dp

    Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Problem Desc ...

  5. hdu 4055 Number String (基础dp)

    Number String Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  6. 训练指南 UVA - 10917(最短路Dijkstra + 基础DP)

    layout: post title: 训练指南 UVA - 10917(最短路Dijkstra + 基础DP) author: "luowentaoaa" catalog: tr ...

  7. 训练指南 UVA - 11324(双连通分量 + 缩点+ 基础DP)

    layout: post title: 训练指南 UVA - 11324(双连通分量 + 缩点+ 基础DP) author: "luowentaoaa" catalog: true ...

  8. 「kuangbin带你飞」专题十二 基础DP

    layout: post title: 「kuangbin带你飞」专题十二 基础DP author: "luowentaoaa" catalog: true tags: mathj ...

  9. M - 基础DP

    M - 基础DP Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descriptio ...

随机推荐

  1. Response对象及常用方法

    void addCookie(Cookie cookie)给客户端添加一个Cookie对象,以保存客户端的信息 void addDateHeader(String name,long value) 添 ...

  2. CSP201609-1:最大波动

    引言:CSP(http://www.cspro.org/lead/application/ccf/login.jsp)是由中国计算机学会(CCF)发起的"计算机职业资格认证"考试, ...

  3. [转]bashrc与profile区别

    作者:KornLee 2005-02-03 15:49:57 来自:Linux先生 /etc/profile:此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行.并从/etc/pro ...

  4. Fluent Python: Classmethod vs Staticmethod

    Fluent Python一书9.4节比较了 Classmethod 和 Staticmethod 两个装饰器的区别: 给出的结论是一个非常有用(Classmethod), 一个不太有用(Static ...

  5. POJ 1739 Tony's Tour(插头DP)

    Description A square township has been divided up into n*m(n rows and m columns) square plots (1< ...

  6. Graph Theory

    Description Little Q loves playing with different kinds of graphs very much. One day he thought abou ...

  7. 华为oj----iNOC产品部-杨辉三角的变形 .

    此题提供三种方法,第一种,一开始就能想到的,设置一个足够大的数组存储生成的杨辉三角,然后进行判断就行,此方法参见:华为oj iNOC产品部-杨辉三角的变形 另一种方法是采用递归: 三角形的每行的个数为 ...

  8. 百度安卓sdk开发

    一 key问题 1 在百度地图api控制台申请key的流程主要用到了app包,开发工具的开发sha1和发布sha1值,这2个值的获取就非常关键了. 一般来说我们都是在windows上开发安卓,使用an ...

  9. Qt-excel文件操作方法

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:Qt-excel文件操作方法     本文地址:http://techieliang.com/ ...

  10. web 性能测试与报告

    web性能测试大家第一都会想到:loadrunner.ab.siege.http_load等工具.但是这些工具生成的测试报告都不是我想要的. 这里给大家推荐一个sitespeed,使用简单,生成非常详 ...