首页 > 其他分享 >AT_DP

AT_DP

时间:2024-03-24 15:35:32浏览次数:19  
标签:状态 方程 frac max DP 转移 dp

攻略

  1. 先设计一个一定保证正确性的状态,可以完全朴素甚至可以n维

  2. 考虑保证正确性的情况下:合并同类状态,消除无用状态,消除无用转移。

  3. 对递推式进行分类,只与当前点有关的直接处理,只与以前相关的点预处理,既与当前有关又与现在有关考虑斜率优化(有单调性用单调队列,否则二分或李超)

A

显然

B

显然

C

显然

D

01背包模板
设 \(dp[i][j]\) 表示考虑了 $i $ 个物品,背包容量为 $ j $ 的最大价值

  • 选第 $ i $ 件物品,那么背包容量剩余 $ j−w_i ,i−1 $ 个物品,价值为 $ dp[i−1][j−w_i]+v_i$
  • 不选第 $ i $ 件物品,那么背包容量仍然不变为 $ j $ ,这时价值为 $ dp[i−1][j] $

所以可以得到 $ dp $ 的转移方程:

$$ dp[i][j]=max(dp[i−1][j−w_i]+v_i,dp[i−1][j])$$

滚动数组状态变为 $ dp[j] $ ,倒序枚举

则原方程变为:

$$ dp[j]=max⁡(dp[j−w_i]+v_i,dp[j]) $$

E

设 $ dp[i][j] $ 表示考虑 $ i $ 个物品,总价值是 $ j $ 所需的最小容量

  • 拿第 $ i $ 件物品,那么别的物品的总价值需要凑出 $ j−v_i $ 考虑 $ i−1 $ 件物品的最优选取方式,即最终重量为 $ dp[i−1][j−v_i]+w_i $ 。

  • 不拿第 $ i $ 件物品,那么别的物品需要凑出 $ j $ 的价值。考虑前 $ i−1 $ 件物品的最优选取方式,即最小重量为 $ dp[i−1][j] $

所以可以得到 $ dp $ 的转移方程:

$$dp[i][j]=min(dp[i−1][j−v_i]+w_i,dp[i−1][j])$$

滚动数组

则原方程变为:

$$ dp[j]=min(dp[j−v_i]+w_i,dp[j])$$

F

设状态 $ dp[i][j] $ 为 $ s $ 的前 $ i $ 项与 $ t $ 的前 $ j $ 项的 LCS

  • 如果 $ s[i]=t[j] $ ,则 $ dp[i][j]=dp[i−1][j−1]+1 $

  • 否则, $ dp[i][j]=max (⁡ dp[i−1][j],dp[i][j−1] )$

同时记录路径,最后从 $ (n,m) $ 向前回溯得到字符串

G

由于该题为有向无环图,因此我们可以按序去搜索遍历每一个点。若该点未被访问过,则对其进行搜索;否则,就可以直接对该点保存的答案进行求最大。

H

显然

I

设 $ dp[i][j] $ 表示前 $ i $ 个元素有 $ j $ 个向上的概率。只需要枚举当前硬币是向上还是向下即可,与背包类似。

转移方程为:

$$ f[i][j]=f[i−1][j−1]×pi+f[i−1][j]×(1−pi) $$

计算完毕后,统计一半硬币向上的答案。

J

考虑最暴力的做法,用 $ dp[a_1][a_2] ... [a_n] $ 表示第 $ i $ 盘还剩 $ a_i $个寿司的期望次数。那么枚举随机到的数 $ i $ 就可以得到方程:

$$ dp[a1][a2]⋅⋅⋅[an]=1+\sum _{i=1}^{n} \frac{1}{n} dp[a1][a2]...[max⁡(a_i−1,0)]...[an] $$

注意到第几盘寿司没有区别,因此可以合并状态,只记录剩余寿司的盘数
因为 $ ai≤3 $ 所以至多有四种不同数值: $ 0,1,2,3$ 。我们重新定义状态 $ dp[a][b][c][d] $ 表示当前还剩下 $ a/b/c/d $ 盘有 $ 0/1/2/3 $ 个寿司。
枚举当前随机到的盘子里还剩几只寿司得到如下方程:

$$dp[a][b][c][d]=1+\frac andp[a][b][c][d]+\frac bndp[a+1][b−1][c][d]+\frac cndp[a][b+1][c−1][d]+\frac dndp[a][b][c+1][d−1]$$

移项整理得到转移方程:

$$ dp[a][b][c][d]=\frac{b+c+d}n+\frac{b+c+d}b​dp[a+1][b−1][c] [d]+\frac{b+c+d}cdp[a][b+1][c−1][d]+\frac{b+c+d}ddp[a][b][c+1][d−1] $$

注意到 \(a+b+c+d=n\)
因此任意三个数可以确定另一个数,所以可以合并状态,又因为 \(a\) 在方程中参与度不高,所以把 \(a\) 这一维压掉。
得到

$$dp[b][c][d]=\frac{b+c+d}n​+\frac{b+c+d}b​dp[b−1][c][d]+\frac{b+c+d}c​dp[b+1][c−1][d]+\frac{b+c+d}d​dp[b][c+1][d−1]$$

K

设状态很重要,如果设某一个人的胜负,每一步状态都需要考虑两个决策,过于困难。

若设状态为当前操作者的胜负,则只需要考虑一个人的决策(其实是因为题面中两人没有本质上的的区别)

设 $ dp[i] $ 表示在剩余 $ i $ 块石头时,当前操作者的胜负。

显然,状态 $ dp[i] $ 可以转移到 $dpi+a_j $ 。

有一个显然的结论:在剩余 $ 0 $ 块石头时,当前操作者必败。

那么,如果一个状态能转移到一个必败状态,那么当前操作者一定必胜。

当前操作者只需要选择转移到那个使对手必败的状态,就可以让自己必胜(这也是博弈论的重要结论)。

所以我们可以从 $ dp[1] $ 开始递推求解,最终答案为 $ dp[k] $ 。

L

显然游戏过程中剩下的数必然是连续的一段。设 $ dp[i][j] $ 表示剩下下标为 $ [i,j] $ 的数时,先手(并非当前的先手而是开始时的先手,下同)能取得的最大分数差。

分两种情况讨论:

  • 已经取走的数为偶数个,此时先手取, $ dp[i][j]=max⁡(dp[i+1][j]+a_i,dp[i][j−1]+a_j) $ 。

  • 已经取走的数为奇数个,此时后手取, $ dp[i][j]=min⁡(dp[i+1][j]−a_i,dp[i][j−1]−a_j) $ 。

还有一种神奇的解法:

考虑数列中存在 $ 3 $ 个连续的数 $ a_i,a_{i+1},a_{i+2} $ 满足 $ a_i≤a_{i+1} $ 并且 $ a_{i+1}≥a_{i+2} $ ,此时一方任取两边的数,则另一方取中间的数最优,所以,这 $ 3 $ 个数可以等效合并为 $ 1 $ 个大小为 $ a_i+a_{i+2}−a_{i+1} $ 的数。

将数列中满足条件的数等效合并完后,数列一定满足先递减后递增,此时从两端贪心即可。

重点在于发现这种合并对全局生效

M

设 $ dp[i][j] $ 表示考虑到第 $ i $ 个小朋友,当前已经用掉 $ j $ 个糖的方案数。

转移方程:

$$dp[i][j]=\sum_{k=max(0,j-a_{i-1})}^jdp[i-1][k] $$

发现公式里每个 $ dp $ 值都由上一行中一段连续的 $ dp $ 值之和转移而来,可以前缀和优化转移。

N

设 $ dp[i][j] $ 为 $ i $ 到 $ j $ 的答案,
则枚举其中间点 $ k $ 取最小值:

合并的代价的最小值。

于是就可以推出转移方程:

$$dp[i][j]=min(dp[i][j],dp[i][k]+dp[k][j]+\sum_{p=i}^{j}a_p )$$

前缀和优化

标签:状态,方程,frac,max,DP,转移,dp
From: https://www.cnblogs.com/WJChp/p/18092483

相关文章

  • ARM64: ARDP
    1指令语法ardp<Xd>,<lable>2指令语义1获取程序计数器PC寄存器的值;2将PC寄存器值的低12位全部取0;3将lable的值乘以4096,也就是将label左移12位;4将第2步的PC值与第3步的label值相加;5将第4步所得结果写入寄存器Xd。从上面步骤可以看出,得到的结果低12位为0,所以得到......
  • TCP/UDP/IP协议 自述
    TCP包协议格式SYN—为1表示这是连接请求或是连接接受请求,用于创建连接和使顺序号同步ACK—为1表示确认号字段有效TCP协议三次握手流程主要就是SYN和ACK字段。服务器开始属于监听状态。1、客户端发送连接请求。SYN置为1.序列号为12342、服务器收到请求。ACK置为1,确......
  • Offer必备算法15_简单多问题dp_八道力扣题(打家劫舍+买卖股票)
    目录①力扣LCR089.打家劫舍解析代码②力扣213.打家劫舍II解析代码③力扣740.删除并获得点数解析代码④力扣LCR091.粉刷房子解析代码⑤力扣309.买卖股票的最佳时机含冷冻期状态机分析解析代码⑥力扣714.买卖股票的最佳时机含手续费状态机分析解析代码⑦......
  • 【蓝桥杯·dp问题】砝码称重
    此题易联想到使用动态规划解决,dp[i][j]状态表示是否存在前i个砝码中选取重量为j的方案。砝码重量分三种情况:1.砝码本身的重量(即一个砝码就可以表示的重量)2.放在同侧3.放在异侧注意重量为0的情况不记作方案数。#include<cstdio>#include<cstring>#include<iostream......
  • 为什么DNS使用UDP(端口号是53)而不是TCP
    DNS(DomainNameSystem)使用UDP(UserDatagramProtocol)而不是TCP(TransmissionControlProtocol)的主要原因是出于性能和效率的考虑。下面详细解释为什么DNS选择使用UDP协议:小型请求和快速响应:DNS查询通常是小型请求,仅需要几个字节的数据传输。UDP是无连接的协议,它不需要在通信之......
  • 高通平台怎么检测充电器类型为SDP,CDP,DCP
    高通平台(QualcommSnapdragon)检测充电器类型SDP(StandardDownstreamPort,标准下行端口)、CDP(ChargingDownstreamPort,充电下行端口)和DCP(DedicatedChargingPort,专用充电端口)是基于USBBatteryChargingSpecification1.2(USBBC1.2)或更高版本的规定实现的。这些充电类型主要是通......
  • 轮廓线 dp
    轮廓线dp是一种和插头dp基本相同的东西,所以先看一下轮廓线dp。TilingDominoes与状压dp不同的是,轮廓线dp是通过逐格转移来进行dp的。我们用三维\(f_{i,j,k}\)来表示dp状态。其中,\(i,j\)表示当前进行到\((i,j)\)这个格子,\(k\)表示轮廓线状态。具体的,在下面......
  • http tcp udp json 接收测试
    创建新的Node.js项目:在您的项目文件夹中打开命令行或终端,并运行以下命令来初始化一个新的Node.js项目:npminit-y安装依赖库:执行以下命令来安装 dgram 模块,它是Node.js提供的用于处理UDP数据的模块:npminstalldgram启动UDP服务器:在命令行或终端中,进入项目文......
  • QT 智能指针 QPointer QScopedPointer QSharedPointer QWeakPointer QSharedDataPoint
    QPointerQPointer是一种受保护的指针,当其引用的对象被销毁时,它会被自动清除(但是,销毁引用对象还是必须手动delete)。QPointer所指向的对象必须是QObject或其派生类对象。当多个指针指向同一个Object对象时,引用的对象可能被释放掉,这时使用QPointer就可以安全的测试引用对象是......
  • 反外挂 DDos UDP 攻击只需客户端 开着游戏客户端
    #include<WINSOCK2.H>#include<iostream>#include<string>usingnamespacestd;#include<stdlib.h>#defineBUF_SIZE1377#pragmacomment(lib,"WS2_32.lib")intmain(){WSADATAwsd;SOCKETsHost;SOCKADDR_INse......