DP---DAG、背包、LIS、LCS
DP是真的难啊,感觉始终不入门路,还是太弱了┭┮﹏┭┮
DAG上的DP
一般而言,题目中如果存在明显的严格偏序关系,并且求依靠此关系的最大/最小值,那么考虑是求DAG上的最短路或者是最长路。(据说还有路径计数的问题,我倒是没遇到,哪位大大看见提醒一下呐)
这类问题可以使用记忆化搜索直接解,但是有爆栈的风险。
数据比较大的情况下,可以使用先求拓扑序,然后按照拓扑序(bfs求拓扑序),进行递推即可。
背包问题
1.完全背包
for (int i = 1; i <= n; i++)
for (int j = w[i]; j <= m; ++j)
f[j] = max(f[j],f[j - w[i]] + v[i]);
完全背包本质就是一个DAG问题,把背包的剩余容量看成状态,边就是物品的体积。
2.01背包
for (int i = 1; i <= n; i++)
for (int j = 0; j <= m; j++)
if (j < w[i])
f[i][j] = f[i-1][j];
else
f[i][j] = max(f[i-1][j],f[i-1][j-w[i]] + v[i]);
简化后
for (int i = 1; i <= n; i++)
for (int j = w[i]; j <= m; ++j)
f[j] = max(f[j],f[j - w[i]] + v[i]);
01背包按刘汝佳的话说是一个多阶段决策问题,或者说是二维dp,也即是需要一个维度来考虑对于物品的使用。
3.多重背包
int f[N],v[N],w[N],n;
for (int i = 1; i <= n0; i++)
{
cin >> wi >> vi >> ci;
for (int j = 1; j <= ci; j <<= 1;)
{
++n;
v[n] = vi * j;
w[n] = wi * j;
ci -= j;
}
if (c > 0)
{
++n;
v[n] = vi * c;
w[n] = wi * c;
}
}
for (int i = 1 ; i <= n; i++)
for (int j = m ; j >= w[i]; j--)
{
f[j] = max(f[j],f[j-w[i]] + v[i]);
}
把未知模型拆分为已知的模型, 把多重背包拆分成多个01背包,具体原则就是把一个数用logn(n为重复个数)来进行表示,使得物品的数量变成O(nlogm),然后复杂度变为O(nmlogm)
4.分组背包
for (int i = 1 ; i <= n; i++)
for (int j = m; j >= 0; j--)
for (int k = 1; k <= len[i]; k++)
{
if(j - g[i][k])
f[j] = max(f[j],f[j-w[i][k]]+v[i][k]);
}
在01背包的基础上,每个物品属于一个组,每组中的物品是互斥的。
5.树形背包
在01背包的基础上,每个物品可能依赖于某个其他物品(需要选定某个前驱物品,才能选这个物品)
1.得到dfs序,和每个结点对应的最远子树结点r
2.按照dfs序从后往前,对于每件物品,考虑它选/不选两种情况如果不选,对应的整颗子树也不选,变成dfs序中子树最后一个的下一个 如果选,变成dfs序中的下一个。
LIS问题
dp[i]表示序列1~i的LCS,进行dp转移即可。
for (int i = 1; i <= n ; i++)
for (int j = 1; j < i; j++)
if (j < i) dp[i] = max(dp[i],dp[j]+1)
可以用树状数组优化,最终结果为dp[n]
LCS问题
dp[i][j]表示第一个序列1i,第二个序列1j位置的LCS。
for(int i = 1; i <= n1; i++)
for(int j = 1;j<=n2;j++)
if (i==j)dp[i][j] = dp[i-1][j-1]+1;
else dp[i][j] = max(dp[i-1][J],dp[i][j-1]);
最终结果为dp[n1][n2];
DP---DAG、背包、LIS、LCS的更多相关文章
- 线性DP总结(LIS,LCS,LCIS,最长子段和)
做了一段时间的线性dp的题目是时候做一个总结 线性动态规划无非就是在一个数组上搞嘛, 首先看一个最简单的问题: 一,最长字段和 下面为状态转移方程 for(int i=2;i<=n;i++) { ...
- dp入门(LIS,LCS)
LCS
- USACO Money Systems Dp 01背包
一道经典的Dp..01背包 定义dp[i] 为需要构造的数字为i 的所有方法数 一开始的时候是这么想的 for(i = 1; i <= N; ++i){ for(j = 1; j <= V ...
- 树形DP和状压DP和背包DP
树形DP和状压DP和背包DP 树形\(DP\)和状压\(DP\)虽然在\(NOIp\)中考的不多,但是仍然是一个比较常用的算法,因此学好这两个\(DP\)也是很重要的.而背包\(DP\)虽然以前考的次 ...
- NYOJ16|嵌套矩形|DP|DAG模型|记忆化搜索
矩形嵌套 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 有n个矩形,每个矩形可以用a,b来描述,表示长和宽.矩形X(a,b)可以嵌套在矩形Y(c,d)中当且仅当a& ...
- HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化)
HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化) 题意分析 先把每种硬币按照二进制拆分好,然后做01背包即可.需要注意的是本题只需要求解可以凑出几种金钱的价格,而不需要输出种数 ...
- HDOJ(HDU).1059 Dividing(DP 多重背包+二进制优化)
HDOJ(HDU).1059 Dividing(DP 多重背包+二进制优化) 题意分析 给出一系列的石头的数量,然后问石头能否被平分成为价值相等的2份.首先可以确定的是如果石头的价值总和为奇数的话,那 ...
- HDOJ(HDU).2191. 悼念512汶川大地震遇难同胞――珍惜现在,感恩生活 (DP 多重背包+二进制优化)
HDOJ(HDU).2191. 悼念512汶川大地震遇难同胞――珍惜现在,感恩生活 (DP 多重背包+二进制优化) 题意分析 首先C表示测试数据的组数,然后给出经费的金额和大米的种类.接着是每袋大米的 ...
- HDOJ(HDU).4508 湫湫系列故事――减肥记I (DP 完全背包)
HDOJ(HDU).4508 湫湫系列故事――减肥记I (DP 完全背包) 题意分析 裸完全背包 代码总览 #include <iostream> #include <cstdio& ...
- HDOJ(HDU).1284 钱币兑换问题 (DP 完全背包)
HDOJ(HDU).1284 钱币兑换问题 (DP 完全背包) 题意分析 裸的完全背包问题 代码总览 #include <iostream> #include <cstdio> ...
随机推荐
- 一、IIS搭建前端静态模板_资源加载问题
一.模板文件说明和效果展示 二.IIS配置模板 三.解决方案 把资源文件复制到html目录内与index.htm同级,因为我iis指定站点就是该目录.
- 基于ldap+sentry+rbac的hive数据库权限测试
1.rbac系统简介 2.sentry系统简介 3.ldap系统简介 4.整个待测系统简介 user-role=group-role user-role是用户在rbac系统创建项目以及把项目成员以及给 ...
- linux 性能分析常用命令汇总
CPU性能分析工具: vmstatpssartimestracepstreetop Memory(内存)性能分析工具:vmstatstracetopipcsipcrmcat /proc/meminfo ...
- [CF1208D] Restore Permutation
传送门 题意:有一个长为\(n\)的排列\(p\),设\(S_i=\sum_{j=1}^{i-1}p_j\cdot[p_j<p_i]\),给出\(S\),要求还原出\(p\).保证有解,\(n\ ...
- App 区别
本文的结构主要分为以下部分: 1.app的分类 2.每类app的定义,明确各类app具体是什么 3.各类app的优缺点 4.具体开发过程中,到底该采用哪种类型的app 1.app的分类 大致可以分为这 ...
- 3分钟教会你把封装的js公共方法挂载在vue实例原型上
第一步:首先在src文件夹里面创建一个通用js文件夹,然后在创建的文件夹里面创建一个js文件 第二步:const 一个方法,然后通过export暴露出来(在同一个页面可以写多个方法,和暴露多个方法,在 ...
- springboot + 注解 + 拦截器 + JWT 实现角色权限控制
1.关于JWT,参考: (1)10分钟了解JSON Web令牌(JWT) (2)认识JWT (3)基于jwt的token验证 2.JWT的JAVA实现 Java中对JWT的支持可以考虑使用JJWT开源 ...
- asp.net大文件上传解决方案
以ASP.NET Core WebAPI 作后端 API ,用 Vue 构建前端页面,用 Axios 从前端访问后端 API ,包括文件的上传和下载. 准备文件上传的API #region 文件上传 ...
- luogu 4147 玉蟾宫 悬线DP
Code: #include<bits/stdc++.h> using namespace std; #define setIO(s) freopen(s".in",& ...
- 上传文件报413 Request Entity Too Large错误解决办法
产生这种原因是因为服务器限制了上传大小 1.nginx服务器的解决办法 修改nginx.conf的值就可以解决了 将以下代码粘贴到nginx.conf内 client_max_body_size 20 ...