DP Training(Updating)
感觉前面做了那么多$dp$全是自己想的还是太少啊……
好像在LZT的博客上看到了不错的资源?赶紧开坑,以一句话题解为主
Codeforces 419B
第一题就开始盗图
由于只有一个交点,手玩一下发现两人的路径可以分为四块区域,且只有两种情况:
预处理四个方向的最长距离,枚举相交点即可
FZU 2234:
将往返路径看成从起点出发的两条路径
$dp[Xa][Xb][STEP]$用三维记录两个当前位置,转移时注意两点是否重复
Tip:建状态时注意是否有能合并的维度!
POJ 1050:
一开始想成最大全1子矩阵了……
这样权值和最大子矩阵好像也只能$O(n^3)$做:
$O(n^2)$枚举左右端点,再转换成1维$O(n)$算一遍从上到下的最长子序列
HDU 1024:
最大$m$字段和我可能之前学的是假的转移……
直接设$dp[i][j]$表示取前$i$个且第$i$个必选的最大$j$字段和,不需要再加一维表示是否选$i$
转移:$dp[i][j]=max(dp[i-1][j],dp[k][j-1])+a[i]$,滚动数组+记录前一层到$i-1$的最大值
Tip:
1、分清哪一层滚动来确定嵌套顺序
2、第二层(i)不能每次从1开始枚举,要从$j$开始!!!
边界尽量卡死防止出错
加强版见:https://www.cnblogs.com/newera/p/9534648.html
HDU 1257:
可以直接贪心判断是否需要增加系统并维护每个系统的末尾值
不过这其实是一道$Dilworth$定理相关的题
借此机会又好好复习了下集合论里的一些概念和证明:传送门
这题将偏序关系设为$i<j$且$a[i]<a[j]$,那么每个系统就是一条反链
最长链长度=最小反链覆盖,因此直接求LIS即可
HDU 1025:
按一边排序后直接LIS,注意输出里的$road$和$roads$……(还是要好好看样例!)
HDU 5282:
这里用$cnt[i][j]$计数时按是否选$a_i$分类:
(注意分类转移的设置!)
1、不选$a_i$:$f[i][j]=f[i-1][j]$时加上$cnt[i-1][j]$
2、选$a_i$:预处理出$b_j$前第一个与$a_i$相同的位置$pre$
$f[i-1][pre-1]+1=f[i][j]$时加上$cnt[i-1][pre-1]$
FZU 2214:
尽量用范围小的量做状态!
POJ 2184:
要求在两个量和都大于0的情况下求最大的和
这样必定不能用和来建状态,而应该以其中一个量作状态用值存另一个量的最大值
UVa 624:
可以把$weight,value$都看成$w[i]$直接做背包
也可以用$vis[i][j]$表示能否凑出$j$
HDU 2639:
求第$K$大背包
转移的项与原来相同,只是对于每个原来状态都记录下前$K$大的值
每次转移时将$2*K$个数$O(n)$合并求出前$K$大即可
HDU 5534:
只要$\sum d_i=2*(n-1)$,那么就存在这样的一棵树
如果将每个点作为第一维那么转移是$O(n)$的,思考如何优化
发现将$d_i$相同的点合并看成一种物品再进行一些处理就能跑完全背包了!
Tips:
1、为了消除物品总数必须为$n$的限制,先给每个点分配1的度数,只考虑增量
这样就变成$W=n-2,num=n-2,w[i]'=w[i]-w[1]$的无限制完全背包了
2、注意这里要求总重量恰为$n-2$,而非至多,因此要把$dp$数组初始化为-INF$
DP Training(Updating)的更多相关文章
- DP Training(Updating)♪(^∇^*)
DP Training DP Training 01 https://vjudge.net/contest/220286 密码 nfls A 数塔(Easy) \(f[i][j]\) 表示当前选第 \ ...
- xtu DP Training C.炮兵阵地
炮兵阵地 Time Limit: 2000ms Memory Limit: 65536KB This problem will be judged on PKU. Original ID: 11856 ...
- xtu DP Training B. Collecting Bugs
B. Collecting Bugs Time Limit: 10000ms Memory Limit: 64000KB 64-bit integer IO format: %lld Jav ...
- (zhuan) 一些RL的文献(及笔记)
一些RL的文献(及笔记) copy from: https://zhuanlan.zhihu.com/p/25770890 Introductions Introduction to reinfor ...
- [C6] Andrew Ng - Convolutional Neural Networks
About this Course This course will teach you how to build convolutional neural networks and apply it ...
- 2017 Multi-University Training Contest - Team 9 1001&&HDU 6161 Big binary tree【树形dp+hash】
Big binary tree Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- 2017 Multi-University Training Contest - Team 1 1003&&HDU 6035 Colorful Tree【树形dp】
Colorful Tree Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)T ...
- Gym - 100676G Training Camp (状压dp)
G. Training Camp[ Color: Yellow ]Montaser is planning to train very hard for ACM JCPC 2015; he has p ...
- 2014 Super Training #9 E Destroy --树的直径+树形DP
原题: ZOJ 3684 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3684 题意: 给你一棵树,树的根是树的中心(到其 ...
随机推荐
- IIC串行总线的组成及其工作原理
------------------最近项目上用到了一款美信的DS1308RTC芯片,由于是挂在了Zynq的PS MIO上,需要软件人员协助才能测试:觉得太麻烦了,想通过飞线,然后在Vivado中调用 ...
- python小工具之读取host文件
# -*- coding: utf-8 -*- # @Time : 2018/9/12 21:09 # @Author : cxa # @File : readhostfile.py # @Softw ...
- 使用postman做接口测试(一)
参考大神的总结:https://www.cnblogs.com/Skyyj/p/6856728.html 一,先了解一下基础知识,虽然工作中没什么卵用,但背会了,可以显摆自己很专业的样子,以下内容来自 ...
- 正则表达式之你不知道的replace
我们都知道js内置类String提供了一个replace方法,可以把指定字符串替换为另一个字符串,他的基础用法如下: var str="hello world"; var str= ...
- Java基础83 JSP标签及jsp自定义标签(网页知识)
1.JSP标签 替代jsp脚本,用于jsp中执行java代码1.1.内置标签: <jsp:forward></jsp:forward> 相当于:request.getReu ...
- java基础19 导包和“命令行”打jar包
1.导包 1.1.包 java中的包就相当于Windows文件夹 编译格式:javac -d . 类名.java 1.2.包的作用 1.解决了类名重复冲突的问题 2.便于软件版本的 ...
- Oracle 中count(1) 、count(*) 和count(列名) 函数的区别
1)count(1)与count(*)比较: 1.如果你的数据表没有主键,那么count(1)比count(*)快2.如果有主键的话,那主键(联合主键)作为count的条件也比count(*)要快3. ...
- iframe框架加载完成后执行函数
var iframe = document.createElement("iframe"); iframe.src = "http://www.baidu.com/&qu ...
- HTML5练习2
1.邮箱注册网页 主要代码: <!doctype html> <html> <meta charset="utf-8"> <title&g ...
- ZooKeeper实践:(2)配置管理
一. 前言 配置是每个程序不可或缺的一部分,配置有多重方式:xml.ini.property.database等等,从最初的单机环境到现在的分布式环境. 1. 以文件的格式存储配置,修改任何都 ...