首页 > 其他分享 > # DP进阶训练:区间dp + 数位dp + 状压dp

# DP进阶训练:区间dp + 数位dp + 状压dp

时间:2023-06-03 17:33:06浏览次数:55  
标签:表示 状态 进阶 状压 数组 转移 dp 数字

DP进阶训练:区间dp + 数位dp + 状压dp

vj题单


A. Multiplication Puzzle (区间dp)

题意:

  • 首先这道题题意大概是:n个数字,每次你能拿走一个数字(除了两边的),贡献是这个数字和两边两个数字的成绩。最后题目要求你按任意顺序拿走n-2个数字,使得贡献和最小。

分析:

  • 顺序: 首先能想到是个dp题,因为在思考时候就是在考虑最优的处理顺序是什么。注意,这里提到了一个很关键的词:顺序,这表示一种策略,显然不能想到合适的贪心思路,那就往dp方向想。
  • 性质: 我在最初思考时候,一般按照yxc dalao的闫式dp分析法,首先先认真分析这道题中存在的性质。(个人的一点看法:每个题不同的性质是解这道题的关键,如果你感觉没有思路,可能是没有抓住或挖掘出关键性质)。本题我认为关键的性质是:三个相邻的数要一同考虑,贡献是a[i - 1] * a[i] * a[i + 1]。三个数考虑的结果是a[i]从数组中删除。一个数组不断删除,会从长数组变成短数组,即若短数组最优解计算出来后,可以反着求出长数组的最优解。这个性质就已经指向了区间dp,因为前面的性质是在区间间转移。
  • 表示: 通过前面分析,你得到了解题思路是dp, 关键性质是区间间的转移方式。接着就应该去思考如何通过dp数组来表示一个局面,或者说dp数组如何定义。误区,再以前做dp题时候我有个误区,就是没有特别看重题目性质分析这一步,这导致我经常在嗯想dp表示和转移。还有个误区就是我总是希望dp数组能表示一个局面,然后再不同的局面间进行dp转移。但事实上具体的局面很难表示这也是我做不出dp题的原因之一。如何去思考dp表示呢:一个很关键的词就是————抽象。试想一下动态规划问题就是在考虑一大堆子状态局面间的转移问题,但是状态表示和状态转移都十分不好想。但是我们有时候看题解会发现他们中状态转移非常丝滑,原因就是状态表示的好,使得两个状态间的转移非常清晰。所以要练习自己抽象的能力,因为好的状态表示它不是表示出一个具体的局面,比如本题中具体局面就是一种剩余数字的结果,如[10, 1, 50 ,5] 这种,我们会发现这怎么表示呀?? 所以好的表示是把这道题涉及的子状态局面划分成多个抽象的集合,每个集合是许多小局面的组合,而这些集合间能有清晰的转移。具体见下图。本题相对简单,因为区间dp一般就是dp[l][r],本题中表示l到r这个区间处理结束的最优解。

  • 转移: 有了好的表示转移是不难的,更多时候表示和转移是放在一块考虑的,单考虑一个可能会让另一个的工作变得难做。本题中是dp[l][r]表示l到r之间处理结束, 那子状态如何贡献给dp[l][r]呢?这里有个关键词:完全覆盖 意思就是在考虑状态转移时要把所有能更新当前状态的子局面都考虑到。所以本题考虑l,r之间的k节点是当前[l,r]数组最后一个更新的,dp[l][r] = min{dp[l][k] + dp[k][r] + a[l] * a[r] * a[k]} dp[l][k] + dp[k][r] 就表示l到k间数字和k到r间数字都删除完的最优结果。我再一开始考虑时犯了个错误,我想的是dp[l][r] = min{dp[l][k] + dp[k + 1][r] + 更新最优值} 相当于我认为先把[l, k] 区间删到最后两个值,再把[k+1,r]删到最后两个值。这里其实犯的错误就是没有完全覆盖,因为我这么想相当于我把k+1留在了最后再考虑是否删除,但是对于[l,r]数组k+1它不是边界数字, 你甚至可以上来就把k+1这个数字删除了, 但我这样想相当于给加了一条限制(就是k+1这个数字留到最后删除),使得原本更新[l,r]的子状态一部分状态因为不满足这个新加的限制,没有用于更新[l,r]状态,这就是没有完全覆盖。
  • 整理一下思路:dp[i][j]表示数组[i,j]之间删除到只剩两边数字时的最优解,转移方程dp[i][j] = min(dp[i][j], dp[i][k] + dp[k][j] + a[i] * a[k] * a[j]) 表示[i,k],[k,j]两个数组都删除到只剩i,k和k,j的最优解的和,然后在[i,k,j]三个数的数组中删除k进行合并,贡献为a[i] * a[k] * a[j]。 初始化:[i,j]长度小于3的初始化为0, 等于3的初始化为 a[i] * a[i + 1] * a[i + 2], 大于3的初始化为INF(因为后面转移时取min)。 结果: dp[0][n - 1]

代码

# 省略头文件
int main() {
    // freopen("../temp.in", "r", stdin);
    // freopen("../temp.out", "w", stdout);
    int n; scanf("%d",&n);
    vector<int> a(n, 0);
    for(int i = 0; i < n; ++ i) {
        cin >> a[i];
    }
    vector<vector<int> > dp(n, vector<int>(n, 0x3f3f3f3f));

    for(int len = 1; len <= n; ++ len) {
        for(int i = 0; i + len - 1 < n; ++ i) {
            int j = i + len - 1;
            if(len < 3) {
                dp[i][j] = 0;
                continue;
            }
            if(len == 3) {
                dp[i][j] = a[i] * a[i + 1] * a[j];
                continue;
            }
            for(int k = i + 1; k < j; ++ k) {
                dp[i][j] = min(dp[i][j], dp[i][k] + dp[k][j] + a[i] * a[k] * a[j]);
            }
        }
    }
    cout << dp[0][n - 1] << endl;
    return 0;
}

标签:表示,状态,进阶,状压,数组,转移,dp,数字
From: https://www.cnblogs.com/A-sc/p/17454292.html

相关文章

  • 【Unity】 HTFramework框架(四十四)【进阶篇】指令系统
    索引指令系统简单使用定义InstructionAgent编辑指令代码执行指令代码指令代码语法基本语法指令关键字注释支持的值类型标识符命名规范进阶使用运行时检视面板指令系统指令系统为Unity动态修补程序、热更新等提供了另一种补充方案,我们可以将任意一段指令代码即时编译并执行(请放心,......
  • PortQry检测服务器TCP端口和UDP端口状态
    PortQry是一种命令行实用工具,它能报告远程计算机上端口(传输控制协议(TCP)和用户数据报协议UDP)的端口状态。可从Microsoft下载中心下载PortQry.exe。若要下载PortQry.exe,请访问以下Microsoft网站:https://www.microsoft.com/en-us/download/details.aspx?id=17148名......
  • Vue进阶(幺零八):npm run build 错误 (node:7852) UnhandledPromiseRejectionWarning: Cs
    (文章目录)一、前言在项目打包过程中,突然报如下错误:Vuenpmrunbuild错误(node:7852)UnhandledPromiseRejectionWarning:CssSyntaxError:xxxx.但是在执行npmrundev过程中,并未错误或告警信息。二、解决方案打开webpack.prod.conf.js,注释掉以下配置代码newOptimiz......
  • 树莓派和esp8266在局域网下使用UDP通信,esp8266采集adc数据传递给树莓派,树莓派在web上
    树莓派和esp8266需要在同一局域网下esp8266使用arduino开发:接入一个电容土壤湿度传感器,采集湿度需要使用adc#include<ESP8266WiFi.h>#include<WiFiUdp.h>constchar*ssid="litianmenzhenbu";constchar*password="LT12345678";constchar*serverIp="192.......
  • 四边形不等式优化dp
    对于转移方程\(c(i,j)=w(i,j)+\min_d(c(i,d)+c(d+1,j))\),存在\(w(i,j)+w(i',j')\lew(i,j')+w(i',j)(i\lei'\lej\lej'\)如何快速求其答案。引理一:\(w(i,j)+w(i',j')\lew(i,j')+w(i',j)\)则\(c(i,j)+c(i',j')......
  • TCP和UDP区别
    TCP是传输控制协议,UDP是用户数据表协议;TCP长连接,UDP无连接;UDP程序结构较简单,只需发送,无须接收;TCP可靠,保证数据正确性、顺序性;UDP不可靠,可能丢数据;TCP适用于少量数据,UDP适用于大量数据传输;TCP速度慢,UDP速度快;......
  • HDU 5542 The Battle of Chibi(树状数组+dp)
    TheBattleofChibiTimeLimit:6000/4000MS(Java/Others)    MemoryLimit:65535/65535K(Java/Others)TotalSubmission(s):1749    AcceptedSubmission(s):621ProblemDescriptionCaoCaomadeupabigarmyandwasgoingtoinvadethewholeSou......
  • ICPC2017网络赛(南宁)子序列最大权值(树状数组+dp)
    https://nanti.jisuanke.com/t/17319LetSSbeasequenceofintegerss_{1}s1,s_{2}s2,......,s_{n}snEachintegerisisassociatedwithaweightbythefollowingrules:(1)Ifisisnegative,thenitsweightis00.(2)Ifisisgreaterthanorequalto10......
  • upc 6902: Trie树 (状压dp)
    6902:Trie树时间限制:1Sec  内存限制:128MB提交:137  解决:19[提交][状态][讨论版][命题人:admin]题目描述字母(Trie)树是一个表示一个字符串集合中所有字符串的前缀的数据结构,其有如下特征:1.树的每一条边表示字母表中的一个字母2.树根表示一个空的前缀3.树上所有......
  • Android通过 SharedPreference 实现用户名与密码的存储与调用
    注:Android实验课(一)的内容一、实验原理1.1实验目标编程实现用户名与密码的存储与调用。1.2实验要求设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedPreference,读取不到该用户名提示用户不存在,用......