DP杂谈【持续更新中】

这篇具有很好参考价值的文章主要介绍了DP杂谈【持续更新中】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

什么是DP?

推荐看一下。

正文

滚动数组优化

在一些空间贼小,时间还好的 DP 题目里,会用到优化空间的小技♂巧——滚动数组优化。

滚动数组,顾名思义,一个会滚动的数组,主要是怎样个滚法呢?接下来我先举一个例子:

e.g

最长公共子序列(LCS)

给出两个整数序列,求这两个序列的†最长公共子序列。
†最长公共子序列:多个序列的共有的最长子序列。

这道题我们不难发现:
我们设 \(f_{i,j}\) 为从 \(1\)\(i\)\(a\) 子序列和从 \(1\)\(j\)\(b\) 子序列的 \(LCS\)
它的状态转移方程即为

\[f_{i,j}= \begin{cases} f_{i-1, j-1} + 1 & a[i]=b[j] \\ max(f_{i-1,j},f_{i,j-1}) & a[i]\ne b[j] \end{cases} \]

我们发现,状态 \(f_{i,j}\) 只依赖于 \(f_{i-1,\dots}\)\(f_{i,\dots}\),那么既然 \(i-2\) 及以后的状态都没用了,那么我们可以把那之前的状态给滚掉,即把第一维套上个 \(\% 2\),思考一下,这里十分的巧妙。

因为 \(mod\) 常数很大,我们为了优化常数,可以使用位运算,即 \(i\% 2\rightarrow i\&1\)\((i-1)\% 2\rightarrow (i\oplus1)\&1\)

这样我们将巨大的 \(O(n^2)\) 的空间压缩到了 \(O(n)\)

费用提前计算

在一些题目里,它状态的每一次转移都会产生后效性,所以用普通的DP是做不了的,那么,我们如何解决这个问题呢?

这时,我们有一种策略,就是既然我已经知道未来会被现在影响,那么为什么我不先把将要影响的算了呢?这,就是费用提前计算。

e.g

Luogu 2365 任务安排
题目描述
\(n\) 个任务排成一个序列在一台机器上等待完成(顺序不得改变),这 \(n\) 个任务被分成若干批,每批包含相邻的若干任务。
从零时刻开始,这些任务被分批加工,第 \(i\) 个任务单独完成所需的时间为 \(t_i\)。在每批任务开始前,机器需要启动时间 \(s\),而完成这批任务所需的时间是各个任务需要时间的总和(同一批任务将在同一时刻完成)。
每个任务的费用是它的完成时刻乘以一个费用系数 \(f_i\)。请确定一个分组方案,使得总费用最小。
对于 \(100\%\) 的数据,\(1\le n \le 5000\)\(0 \le s \le 50\)\(1\le t_i,f_i \le 100\)

我们先设 \(dp_i\) 为前 \(i\) 天的答案,\(time_i\) 为前 \(i\) 天完成后的时间,经过手玩样例过后发现状态转移方程为:

\[dp_i=min\{dp_j+(time_j+s+\sum^i_{k=j+1}t_{k})*\sum^i_{k=j+1}f_k\} \]

对于 \(time_j\),我们可以表示为:

\[time_j = \sum^j_{k=1}t_k\times f_k+num*s \]

\(num\) 为前 \(i\) 天做的次数。

怎么处理 \(num\) 呢?考虑到在每次做任务时,都会使当前和以后计算的时间加上 \(s\),先不管转移方程,我们现在对未来的影响为:

\[\sum^n_{k=j+1}s\times f_k=s\times\sum^n_{k=j+1} f_k \]

于是我们可以列出一个船新的状态转移方程:

\[dp_i=min\{dp_j+\sum^i_{k=1}t_k\times\sum^i_{l=j+1}f_l+s\times\sum^n_{k=j+1} f_k\} \]

因为我们在过去已经计算了影响现在的值,所以我们只需要计算 \(\sum^i_{k=1}t_k\)。以上的各种 \(\sum\) 均可以用前缀和优化为 \(O(1)\) 的,所以时间复杂度为 \(O(n^2)\)

数位DP

数位DP主要解决的是有关每个数位上的数字的一些关系,这种DP比较容易辨认,大多是一眼题,形如:

\(l\)\(r(1\le l,r\le 10^{18})\) 中满足以下性质的数的个数:

每个数位.........

我们可以使用类似前缀和的思想,设 \(dp(i)\)\(1\)\(i\) 一共满足性质的数的个数,答案即为 \(dp(r) - dp(l-1)\)

发现可以对于一个已经固定最高位了的任意满足条件的 \(k\) 位数的数量进行预处理,但是这个做法会假掉,原因:先设原数等于 \(\overline{kabcd\cdots e}\)\(x\) 位数),则我们在处理满足性质的最高位为 \(k\)\(x\) 位数的个数可能会包含超出原数范围的数,但是这部分的数是不可取的,并且难以维护 \(\overline{kabcd\cdots e}\) 以内的满足性质的最高位为 \(k\)\(x\) 位数的个数,所以做法假了。

注意到最高位小于 \(k\) 时,我们是可以使用上文预处理的方法的,于是我们可以分类讨论:

DP杂谈【持续更新中】
列出以上树形图

对于左边的分支,我们可以直接用先前预处理出来的值来更新 \(ans\),对于右边的分支,继续往下走,记录一下前面数位的情况,再针对前面的数位来进行下一位的转移。

e.g.

AcWing 1081度的数量
求给定区间 \([X,Y]\) 中满足下列条件的整数个数:这个数恰好等于 \(K\) 个互不相等的 \(B\) 的整数次幂之和。
例如,设 \(X=15,Y=20,K=2,B=2\),则有且仅有下列三个数满足题意:
\(17=2^4+2^0\quad 18=2^4+2^1\quad 20=2^4+2^2\)

简化题意

\(X\)\(Y\) 中满足在 \(B\) 进制下是一个 \(1\) 的个数为 \(K\)\(01\) 串的数的个数。

思路

我们将转为 \(B\) 进制的数拿出来讨论:

于是我们只需要预处理一下 \(C\) 数组(排列组合),在处理右分支时统计前面数位一的个数,如果大于了 \(K\) 的话break即可。文章来源地址https://www.toymoban.com/news/detail-449496.html

.................

到了这里,关于DP杂谈【持续更新中】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 从01背包开始动态规划:暴力解法 + dp + 滚动数组 + dp优化

        01背包问题是动态规划中最经典的问题之一,本篇将通过给出其四种解法,使读者更深刻理解动态规划。   有N件物品和一个容量是 V 的背包,每个物品有各自的体积和价值,且每个物品只能放一次(这也是01背包名字的由来),如何让背包里装入的物品具有最大的价值总

    2024年04月17日
    浏览(54)
  • Flutter vs 前端 杂谈:SliverAppBar、手动实现Appbar、前端Html+JS怎么实现滚动变化型Appbar - 比较

    Flutter vs 前端 杂谈 SliverAppBar的弹性背景的显隐效果使用Html+JS怎么实现 作者 : 李俊才 (jcLee95):https://blog.csdn.net/qq_28550263 邮箱 : 291148484@163.com 本文地址 :https://blog.csdn.net/qq_28550263/article/details/134149018 在 Flutter 中,最简单的 appbar 就是 Appbar 组件,它没有任何难点,任何刚

    2024年02月05日
    浏览(59)
  • 力扣hot100 打家劫舍 DP 滚动数组

    Problem: 198. 打家劫舍 👨‍🏫 参考地址 时间复杂度: O ( n ) O(n) O ( n ) 空间复杂度: O ( n ) O(n) O ( n ) 空间复杂度: O ( 1 ) O(1) O ( 1 )

    2024年01月19日
    浏览(42)
  • 畅联云杂谈一:什么是畅联云平台

    畅联AIoT开放云平台( http://www.24hlink.cn )由杭州美畅物联技术有限公司推出的,专为AIoT开发赋能的PaaS平台,畅联云平台解决各种视频、物联网终端、算法的在云上的统一接入、汇聚、管理、赋能等问题,为智慧城市、智慧教育、智慧园区、智慧工地、数字乡村等领域甚至为

    2024年02月03日
    浏览(44)
  • 【JSP技术】web杂谈(2)之JSP是什么?

    什么是JSP,JSP的特点,JSP的未来趋势,JSP的应用范例。深入了解JSP技术。 原创于:CSDN博主-《拄杖盲学轻声码》,更多内容可去其主页关注下哈,不胜感激 更多考试总结可关注CSDN博主-《拄杖盲学轻声码》 服务器动态网页(JSP,JavaServerPages)是由Sun公司(SunMicrosystemsInc)倡导

    2024年02月11日
    浏览(41)
  • dp 就 dp ,数位dp是什么意思 ?

                                                                       💧 dp 就 dp ,数位dp是什么意思 ?💧           🌷 仰望天空,妳我亦是行人.✨ 🦄 个人主页——微风撞见云的博客🎐 🐳 数据结构与算法专栏的文章图文并茂🦕生动形

    2023年04月16日
    浏览(37)
  • 【XML技术】web杂谈(3)之深入理解什么是XML、XML的语法详解

    什么是 XML,XML的特征,XML的基本语法及应用,应用程序接口(DOMSAX),XML的文档的显示,深入了解XML技术。 原创于:CSDN博主-《拄杖盲学轻声码》,更多内容可去其主页关注下哈,不胜感激 Web 上的文档组织包含了服务器端文档的存储方式、客户端页面的浏览方式以及传输方

    2024年02月11日
    浏览(44)
  • Kubernetes 笔记(14)— 滚动更新、定义应用版本、实现应用更新、管理应用更新、添加更新描述

    滚动更新,使用 kubectl rollout 实现用户无感知的应用升级和降级。 在 Kubernetes 里,版本更新使用的不是 API 对象,而是两个命令: kubectl apply 和 kubectl rollout ,当然它们也要搭配部署应用所需要的 Deployment 、 DaemonSet 等 YAML 文件。 我们常常会简单地认为“版本”就是应用程序的

    2023年04月19日
    浏览(45)
  • k8s 滚动更新控制(一)

    在传统的应用升级时,通常采用的方式是先停止服务,然后升级部署,最后将新应用启动。这个过程面临一个问题,就是在某段时间内,服务是不可用的,对于用户来说是非常不友好的。而kubernetes滚动更新,将避免这种情况的发生。 对于Kubernetes集群来说,一个service可能有多

    2024年02月13日
    浏览(44)
  • Python学习笔记(持续更新)

    目录 一、基础语法 1.Print()函数  2.变量的定义和使用 3.整数类型  4.浮点类型 5.布尔类型 6.字符串类型 7.数据类型转换 8.注释 9.input()函数 10.算术运算符 11.赋值运算符 12.比较运算符 13.布尔运算符 14.逻辑运算符 15.运算符的优先级 16.对象的布尔值 二、结构 1.分支结构 2.ra

    2024年02月10日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包