2018.8.17 2018暑假集训 关于dp的一些感想(以目前的知识水平)
学了这么长时间的dp似乎还是不怎么样
谨以此篇文字记录一年以来与dp斗智斗勇的各种经历
关于dp(也就是动态规划)似乎对于每个OIer来说都是一个永远的噩梦。

刚刚开始学dp的时候完全搞不明白(只是觉得好厉害的样子) 完全停留在刚刚好能够看懂转移方程的阶段
事实上dp这个东西和其他任何算法都不太一样,同样是仅仅看不可能学会,但是更加可恶的一点是,你仅仅是看,不仅学不会,而且基本上什么东西都学不来。
说到底,毕竟哪个题都不一样,基本上不可能考到同样的题同样的转移方程(可惜当时并不明白这个道理)。
于是甚至在之后的几个月,对于每个和dp有关系的题,基本上都是看题解——想一想——就交了。。。。。。
导致在这半年中,不管其他算法,我的dp可以说没有半点大的进展。
直到我终于下定决心在洛谷上刷了三四十道dp之后。

所谓刷了三四十道dp,不过是在看了题解之前多想了两三个小时而已(大家千万不要学我Q_Q)
尽管如此,仍然是量变导致质变,总算明白了一点dp究竟是啥
所谓dp这个东西,其实就是状态的表示、初始化以及从一个状态向另一个状态的转移(废话)
关于书上写的那个无后效性 其实就是判断能不能用dp做‘
有很多人曾经问过我和我们一些同学dp究竟是啥,说的通俗一点,其实就是一个每个点只搜了一次的搜索,只不过搜索的顺序比较玄学,所以扯到了各种各样的状态之类的东西。
对于本人现在的水平 重点就是状态的划分
比如说01背包 就是对于每个物品的装和不装的枚举,再比如说摆花,就是对于每盆花摆在哪里的枚举。(其实很多题都可以经过多次推导变化成这两个题,以后会再提)
很多时候会想,dp的数组究竟应该怎么开,开几维才能不TLE以及MLE
后来总算想起来一个方法,就是枚举变量
对于我们这种水平的蒟蒻来讲,一般求什么dp的结果就是什么 这是一个变量
为了方便起见,我们把题目中可视的或者较为明显的称为一阶变量,需要经过一阶变量推出的称为二阶变量,同样的可以推出n阶变量,其中包括结果在内的任何一个变量都可以是一到n阶变量(只要你用得比较熟练这个方法应该可以一直用下去)
假设我们已经根据题面初步计算出了在不会TLE及MLE的情况下最多几维dp
这样我们在选取变量作为参数的过程中就可以根据位置的个数选取不同阶数的变量进行状态的表示了
关于对状态的初始化
其实重点就是在可以手算或者心算的边界条件中选取必要的作为初始化的结果
当然还有 例如对每个状态初始值的设定用来判断状态是否有效或者对累加的设置等
关于对状态的转移
刚才已经提到过了状态的划分,其实状态的转移就是从前一个状态转移到后一个状态
通常情况下,对于转移方程来讲,主体一定是对当前状态的操作
例如01背包的二维转移方程 dp[i][v]=max(dp[i-1][v],dp[i-1][j-w[i]]+c[i])其实就是对第i件物品“取与不取”的操作
最后再注意一下循环的顺序以及方向等细节就可以了
上述这些文字,作为一年中与dp斗智斗勇的一部分经历,也算是OI生涯中的一部分吧。
2018.8.17 2018暑假集训 关于dp的一些感想(以目前的知识水平)的更多相关文章
- [暑假集训--数位dp]LightOj1205 Palindromic Numbers
A palindromic number or numeral palindrome is a 'symmetrical' number like 16461 that remains the sam ...
- [暑假集训--数位dp]hdu3709 Balanced Number
A balanced number is a non-negative integer that can be balanced if a pivot is placed at some digit. ...
- [暑假集训--数位dp]hdu3555 Bomb
The counter-terrorists found a time bomb in the dust. But this time the terrorists improve on the ti ...
- [暑假集训--数位dp]hdu3652 B-number
A wqb-number, or B-number for short, is a non-negative integer whose decimal form contains the sub- ...
- [暑假集训--数位dp]hdu2089 不要62
杭州人称那些傻乎乎粘嗒嗒的人为62(音:laoer).杭州交通管理局经常会扩充一些的士车牌照,新近出来一个好消息,以后上牌照,不再含有不吉利的数字了,这样一来,就可以消除个别的士司机和乘客的心理障碍, ...
- 暑假集训 || 概率DP
Codeforces 148D 考虑状态转移..https://www.cnblogs.com/kuangbin/archive/2012/10/04/2711184.html题意:原来袋子里有w只白 ...
- 暑假集训 || 树DP
树上DP通常用到dfs https://www.cnblogs.com/mhpp/p/6628548.html POJ 2342 相邻两点不能同时被选 经典题 f[0][u]表示不选u的情况数,此时v ...
- 暑假集训 || 区间DP
区间DP 经典石子合并问题V1 复杂度 On3 int a[SZ], sum[SZ], f[SZ][SZ]; int main() { int n; scanf("%d", ...
- [暑假集训--数位dp]hdu5787 K-wolf Number
Alice thinks an integer x is a K-wolf number, if every K adjacent digits in decimal representation o ...
随机推荐
- 常用cl编译命令参数解释
紧接前文,第一行cl命令如下: 1> cl /c /IC:\...\include /ZI /nologo- /W3 /WX- /sdl /Od /Oy- /D WIN32 /D _DEBUG ...
- 系统引导文件之 boot.ini(有很多参数)
Windows NT类的操作系统,也就是Windows NT/2000/XP中,有一个特殊文件,也就是“BOOT.INI”文件,这个文件会很轻松地按照我们的需求设置好多重启动系统. “BOOT.INI ...
- Fidder模拟发送请求
在Fiddler的Composer一栏,可以模拟请求 举例 首先通过浏览器访问页面http://baidu.com/ ,在右侧可以拿到请求情况 在Inspectors一栏可以看到请求和响应结果,复制请 ...
- typescript调用javascript && URI.js
URI.js URI.js是一个用于处理URL的JavaScript库它提供了一个“jQuery风格”的API(Fluent接口,方法链接)来读写所有常规组件和许多便利方法,如.directory() ...
- WCF的几个注意事项
wcf托管服务注意的问题 加上项目分为客户端-WCF服务-逻辑层-数据库三层wcf一直出现异常,说没有初始化啊之类的,如果你的逻辑代码确定没有问题的话,思考是不是wcf的配置文件(app.config ...
- 通通玩blend美工(2)——时钟
原文:通通玩blend美工(2)--时钟 谢谢大家对我上一篇Blend的支持:通通玩blend美工(1)——荧光Button 再接再厉再来一篇~~! 这篇是建立在已经看得懂上一篇为基础来写的,有些细节 ...
- Spring 核心技术(1)
接上篇:Spring 框架概述 version 5.1.8.RELEASE 这部分参考文档涵盖了 Spring Framework 所有绝对不可或缺的技术. 其中最重要的是 Spring Framew ...
- Delphi 7下最小化到系统托盘(主要是WM_TRAYMSG和WM_SYSCOMMAND消息)
在Delphi 7下要制作系统托盘,只能制作一个比较简单的系统托盘,因为ShellAPI文件定义的TNotifyIconData结构体是比较早的版本.定义如下: 123456789 _NOTIFY ...
- WPF如何判断PNG中的点是透明的
最近想用WPF做个空战游戏,其中就要解决子弹是否击中飞机的问题.这里面飞机用了PNG图片,大家都知道飞机是不规则图案,如何判断子弹碰撞成了一个难题. 好在我在网上找到了一个可以获取bitmap像素点颜 ...
- 发布ActiveX控件
最近我们正在研究ActiveX技术.我们使用Delphi 5创建了一个具有ActiveForm的ActiveX控件应用程序.这个控件产生一个.OCX文件.现在,我们需要把这个控件部署在服务器端,在用户 ...