DP的力量不是无穷的。

  但是,因为它叫做“动态规划”,它在OI界如鱼得水。这个“动态”不是指“离线”与“在线”,也不是什么“可持久化”。它只是把问题抽象为一个个“阶段”,在每一个“阶段”中作出或繁或简的“决策”,并以此实现“状态”与“状态”间的“转移”。

  正如紫书所言,动态规划的理论性和实践性都很强,一方面需要理解“状态”、"状态转移"、“最优子结构”、“重叠子问题”等概念,另一方面又需要根据题目的条件灵活设计算法。

  “根据题目的条件灵活设计算法”,可以说

希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。

——鲁迅

  也可以说,对动态规划的掌握情况在很大程度上能直接影响一个选手的分析与建模能力。


  分析与建模,是一种十分重要的能力。刘汝佳说,难题无外乎分三种:

  • 难想的
  • 难做的
  • 难调的

  分析与建模,便在很大程度上是关于“思考”。所以伟大的Scanf说,你写出了转移方程,就可以了。

  但真的是“可以”了吗?我的答案是否定的。

  因为其实,想、做、调三者应该是一体的。(在此时Scanf让我们提意见,ZJC说进新机房,臣附议)

  DP优化就是一个典例。因为出题人的缘故(满满的仇恨感),每一次决策的时间必须压缩,或是要简化状态本身。空间就是一个极大的牺牲品。DP本身即建立在“MLE”与“TLE”的夹缝之中,所以每一次优化总是让人伤透脑筋。只要一点没有想清楚,想要“做出来”便很难,“调出来”往往更难。

  所以,DP之伊始即是“分析与建模”。对于这类问题,Scanf总是说:“我们的同学是有思路的~只是实现能力没有起来~”

  其实,任何代码在开始前思路便能很清楚,甚至精确到行,那么实现往往不是大问题。然而“我们的同学”(包括我)更多时候只是“有思路”,且不说“思路”正确与否,即使正确也很难一步到位。

SCOI 2017 酱油记

April 9, 2017

省选终于考完了啊。。
Day1:
先用10分钟浏览了一遍题
看了看t1,感觉贪心好像是对的啊,写了个堆搞一搞
再看t2,最近点似乎可以用点分,再加个树剖维护第一个未签到点,于是码码码,码完3.5h了
一看t3,卧槽计算几何啊。。写了发暴力。然后想到一个n^2sqrt的kd树做法,后来没调出来
最后230
Day2:
又先用10分钟浏览了一遍题
t1切了
t2是两道题加起来的,都可以O(n),然而我都只会nlog,于是T了40
t3写了一个能过大样例的n^2log暴力,但最后只得了10分。。orz
最后170
总分400,似乎挺靠前的

  仔细看看上面这段,MCFX同学的总结,你并不能看出他有任何的“特异功能”,遇到题目很多时候也会卡壳。但是他会深入的思考,会分析,会实践。

  再次反观我,我很多时候太急了,没有掌握好节奏,没有真正想清楚,效率就总是很低。

  当然,也不能一刀切,常常在码题的时候,灵光一闪,没准就创造了一种新算法。


  动态规划是一种用途很广的问题求解方法,它本身并不是一个特定的算法,而是一种思想,一种手段。动态规划的核心是状态和状态转移方程。遇见原问题,就把它分解为相对简单的子问题。

  最优子结构性质,子问题重叠性质,无后效性。

  从递推开始,再到背包,LIS,LCS。

  之后是区间DP。

  终于树形DP来了。(DAG的拓扑性质)

  不厚道的就来了:

    FLOYD,(结合图论)

    数位DP,(数的统计)

    状压DP,(结合二进制)

    概率DP,期望DP,(结合数学)

  既然可以结合数学,那为什么不结合数据结构啊?或者不结合数据结构,直接简化?

  • 倍增优化
  • 单调队列优化
  • 斜率优化
  • 四边形不等式优化
  • ......

  但是,还有,插头、轮廓线……DP是人总结出来的,是永无止境的。

20170520 DP阶段总结的更多相关文章

  1. 2020.7.19 区间dp阶段测试

    打崩了-- 事先说明,今天没有很在状态,所以题解就直接写在代码注释里的,非常抱歉 T1 颜色联通块 此题有争议,建议跳过 题目描述 N 个方块排成一排,第 i 个颜色为 Ci .定义一个颜色联通块 [ ...

  2. 2020.7.19 区间 dp 阶段测试

    打崩了-- 事先说明,今天没有很在状态,所以题解就直接写在代码注释里的,非常抱歉 T1 颜色联通块 此题有争议,建议跳过 题目描述 N 个方块排成一排,第 i 个颜色为 Ci .定义一个颜色联通块 [ ...

  3. AHOI中国象棋(dp)

    大力dp题. 每行每列最多放两个,考虑用行作为dp阶段. dp[i][j][k]表示i行,有一个的有j列,有两个的有k列. 然后就是分类讨论. 一个都不放,放一个在0出,放一个在1出,放两个在0,放两 ...

  4. DP重开

    颓了差不多一周后,决定重开DP 这一周,怎么说,学了学trie树,学了学二叉堆,又学了学树状数组,差不多就这样,然后和cdc一番交流后发现,学这么多有用吗?noip的范围不就是提高篇向外扩展一下,现在 ...

  5. LibreOJ 题解汇总

    目录 #1. A + B Problem #2. Hello, World! #3. Copycat #4. Quine #7. Input Test #100. 矩阵乘法 #101. 最大流 #10 ...

  6. CDQZ 2017 游记

    Day0: 提前放了一整天假,颓过去了.老吕让我去给B层的讲课,ppt还没做,只能在飞机上赶了QAQ.然后从上午到了衡水就一直在路上或者天上,到了晚上才到学校,然而ppt还是没有做完.还有,鄂尔多斯真 ...

  7. openjudge4979 - 海贼王之伟大航路 题解

    原题链接 题目简要分析 N个点,从1号点到N号点求最短路径,且每个点都要遍历到.现在要你求出最优方案. 这道题看到后,首先的想法莫过于搜索.暴力了.这显然不太可能.而进一步思考,使用Floyed和Di ...

  8. 最大子段和之M子段和

    最大M子段和 题目模型 N个整数组成的序列 \(a_1,a_2,a_3,-,a_n\) ,将这N个数划分为互不相交的M个子段,并且这M个子段的和是最大的. 问题分析 方法一: 看到序列,我们首先要尝试 ...

  9. POJ 1946 Cow Cycling(抽象背包, 多阶段DP)

    Description The cow bicycling team consists of N (1 <= N <= 20) cyclists. They wish to determi ...

随机推荐

  1. HPUX系统启动后主机名为unknown的解决办法

    HPUX系统启动完成后,主机名为unknown,查看/etc/rc.log出现如下报错:   unknown:[/]grep -i error /etc/rc.log /sbin/rc1.d/S320 ...

  2. Django数据库 相关之select_related/prefetch_related

    - 性能相关 user_list = models.UserInfo.objects.all() for row in user_list: # 只去取当前表数据 select_related,主动连 ...

  3. export命令详解

    基础命令学习目录首页 export 的基本作用就是将父shell中的局部变量设置为环境变量,使得该变量可以在子shell中使用.下面设置两种情景对export进行原理解析. 情景  1. 有一个名为m ...

  4. centos7安装oracle的一些问题

    在配置监听的时候尝试了很多次都是不能创建,最后将 /data/oracle/product/11.2.0/db_1/network/admin目录下的listener.ora和tnsname.ora两 ...

  5. sublime编写markdownm

    sublime编写markdownm 以前用有道云笔记,找了半天更改字体大小,结果还找不 到,那个字实在是太小了,像我这种有强迫症的患者,实 在受不了简约风格的有道云,所以上网找了与和诺插件并 受到一 ...

  6. 数据库,总结,新技能get

    上来先粘代码吧,这篇本来就不是用来让你们看的,我就是单纯的记录下,嗯~对,总结!!! 首先:first //绑定年份 YearSearch.Items.Clear(); for (int i = Da ...

  7. 修改MyEclipse工作空间

    MyEclipse如何更改工作空间,MyEclipse是java开发常用工具,在开发的过程中我们会经常切换工作空间来切换项目内容,初学者来说有必要讲一下如何切换工作空间 工具/原料   MyEclip ...

  8. C#简单窗体应用程序(一)

    使用C#创建控制台应用程序的基本步骤: (1)创建项目: (2)用户界面设计: (3)属性设置: (4)编写程序代码: (5)保存.调试.运行: 例题:创建一个Windows窗体应用程序,在窗体中添加 ...

  9. poj 1144(割点)

    题目链接:http://poj.org/problem?id=1144 题意:给出一个无向图,求关键节点的个数. 分析:双连通分量Tarjan算法直接求割点就行了,裸的模板题. AC代码: #incl ...

  10. VBA笔记(一)——基础配置

    开启VBA编程环境——VBE 方法一:按<Alt+F11>组合建 方法二:查看代码 宏设置 当然启用宏的设置方式不同,宏的启动方式也不一样. 首先打开“office 按钮”,选择“exce ...