博客
关于我
密码脱落(区间dp,最长公共子序列)
阅读量:747 次
发布时间:2019-03-21

本文共 1351 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要找出一个由A、B、C、D四种字符构成的字符串,使其至少脱落多少个字符后变成反转对称的字符串。我们可以使用动态规划的方法来解决这个问题。

方法思路

我们的任务是把给定的字符串转换成一个回文字符串。为了解决这个问题,我们可以使用动态规划来找出最长回文子序列的长度。通过计算这个长度,我们就可以确定至少需要脱落多少个字符。

具体步骤如下:

  • 初始化一个二维数组dp,其中dp[l][r]表示从位置l到位置r的最长回文子序列的长度。
  • 遍历字符串的所有长度,从1到字符串的长度。
  • 对于每一个长度,将所有可能的起始和结束位置(l, r)进行处理。如果字符相同,则当前区间的最长回文长度等于内部相似区间的长度加2;否则,取左右相邻区间中的较大者。
  • 最终的最长回文子序列的长度可以通过dp[0][n-1]得到,脱落数量为字符串长度减去这个长度。
  • 解决代码

    #include 
    #include
    using namespace std;int main() { string s; cin >> s; int n = s.size(); if (n == 0) { cout << 0; return 0; } vector
    > dp(n, vector
    (n, 0)); for (int len = 1; len <= n; len++) { for (int l = 0; l < n - len + 1; l++) { int r = l + len - 1; if (s[l] == s[r]) { if (l + 1 > r - 1) { dp[l][r] = 2; } else { dp[l][r] = dp[l + 1][r - 1] + 2; } } else { dp[l][r] = max(dp[l + 1][r], dp[l][r - 1]); } } } int max_len = dp[0][n - 1]; cout << n - max_len << endl; return 0;}

    代码解释

  • 读取输入字符串s
  • 初始化动态规划数组dp,大小为n x n,其中n是字符串长度。
  • 遍历字符串的所有长度,从1到n
  • 对于每个长度,遍历所有可能的起始位置l和结束位置r
    • 如果字符s[l]s[r]相同,则dp[l][r]设为内部相似区间的长度加2。
    • 否则,设为左右相邻区间中的较大者。
  • 输出字符串长度减去最长回文子序列的长度,即为至少脱落的字符数量。
  • 通过这种方法,我们可以高效地解决问题,并确保代码的正确性。

    转载地址:http://jhagz.baihongyu.com/

    你可能感兴趣的文章
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>
    Openlayers高级交互(9/20):编辑图形(放缩、平移、变形、旋转),停止编辑
    查看>>
    Openlayers:DMS-DD坐标形式互相转换
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>
    OpenLDAP(2.4.3x)服务器搭建及配置说明
    查看>>
    OpenLDAP编译安装及配置
    查看>>
    Openmax IL (二)Android多媒体编解码Component
    查看>>
    OpenMCU(一):STM32F407 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(二):GD32E23xx FreeRTOS移植
    查看>>
    OpenMCU(五):STM32F103时钟树初始化分析
    查看>>
    OpenMCU(四):STM32F103启动汇编代码分析
    查看>>
    OpenMetadata 命令执行漏洞复现(CVE-2024-28255)
    查看>>
    OpenMMLab | AI玩家已上线!和InternLM解锁“谁是卧底”新玩法
    查看>>
    OpenMMLab | S4模型详解:应对长序列建模的有效方法
    查看>>
    OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
    查看>>
    OpenMMLab | 不是吧?这么好用的开源标注工具,竟然还有人不知道…
    查看>>
    OpenMMLab | 如何解决大模型长距离依赖问题?HiPPO 技术深度解析
    查看>>
    OpenMMLab | 面向多样应用需求,书生·浦语2.5开源超轻量、高性能多种参数版本
    查看>>