【LeetCode】动态规划—712. 两个字符串的最小ASCII删除和(附完整Python/C++代码)

news2025/1/16 5:46:59

动态规划—712. 两个字符串的最小ASCII删除和

  • 前言
  • 题目描述
  • 基本思路
    • 1. 问题定义
    • 2. 理解问题和递推关系
    • 3. 解决方法
      • 3.1 动态规划方法
      • 3.2 空间优化的动态规划
    • 4. 进一步优化
    • 5. 小总结
  • 代码实现
    • Python
      • Python3代码实现
      • Python 代码解释
    • C++
      • C++代码实现
      • C++ 代码解释
  • 总结:

前言

在字符串处理的过程中,如何有效地将两个字符串转换为相同的形式是一个重要的问题。最小 ASCII 删除和问题提供了一种评估字符串相似性的有效方法,通过计算所需删除字符的 ASCII 值和,为我们提供了清晰的转换成本。本文将探讨这一问题的基本思路,并给出动态规划的实现方法,最后展示 Python 和 C++ 的具体代码。

题目描述

在这里插入图片描述

基本思路

1. 问题定义

最小 ASCII 删除和问题要求我们找出将两个字符串 s 1 s 1 s1 s 2 s 2 s2 转换为相同字符串所需删除的字符的最小 ASCII 值之和。换句话说,计算出为了使两个字符串相同,所需删除的字符的 ASCII 值的总和。

2. 理解问题和递推关系

  • 对于两个字符串 s 1 s 1 s1 s 2 s 2 s2 ,我们可以定义 dp[i][j] 为将 s 1 s 1 s1 的前 i i i 个字符和 s 2 s 2 s2 的前 j个字符变为相同的最小 ASCII 删除和。
  • 递推关系如下:
    • 如果 s 1 [ i − 1 ] = = s 2 [ j − 1 ] s 1[i-1]==s 2[j-1] s1[i1]==s2[j1] ,那么不需要删除任何字符, d p [ i ] [ j ] = d p [ i − 1 ] [ j − 1 ] d p[i][j]=d p[i-1][j-1] dp[i][j]=dp[i1][j1]
    • 如果 s 1 [ i − 1 ] ! = s 2 [ j − 1 ] s 1[i-1]!=s 2[j-1] s1[i1]!=s2[j1], 则有三种情况:
      • 删除 s 1 [ i − 1 ] s1[i-1] s1[i1],代价为 ord ⁡ ( s 1 [ i − 1 ] ) + d p [ i − 1 ] [ j ] \operatorname{ord}(s 1[i-1])+d p[i-1][j] ord(s1[i1])+dp[i1][j]
      • 删除 s 2 [ j − 1 ] s 2[j-1] s2[j1] ,代价为 ord ⁡ ( s 2 [ j − 1 ] ) + d p [ i ] [ j − 1 ] \operatorname{ord}(s 2[j-1])+d p[i][j-1] ord(s2[j1])+dp[i][j1]
      • 同时删除 s 1 [ i − 1 ] s 1[i-1] s1[i1] s 2 [ j − 1 ] s 2[j-1] s2[j1] ,代价为 ord ⁡ ( s 1 [ i − 1 ] ) + ord ⁡ ( s 2 [ j − 1 ] ) + dp ⁡ [ i − 1 ] [ j − \operatorname{ord}(s 1[i-1])+\operatorname{ord}(s 2[j-1])+\operatorname{dp}[i-1][j- ord(s1[i1])+ord(s2[j1])+dp[i1][j 1].
    • 因此,综合以上情况:

d p [ i ] [ j ] = min ⁡ ( d p [ i − 1 ] [ j ] + ord ⁡ ( s 1 [ i − 1 ] ) , d p [ i ] [ j − 1 ] + ord ⁡ ( s 2 [ j − 1 ] ) , d p [ i − 1 ] [ j − 1 ] + ord ⁡ ( s 1 [ i − 1 ] ) + ord ⁡ ( s 2 [ j − 1 ] ) ) d p[i][j]=\min (d p[i-1][j]+\operatorname{ord}(s 1[i-1]), d p[i][j-1]+\operatorname{ord}(s 2[j-1]), d p[i-1][j-1]+\operatorname{ord}(s 1[i-1])+\operatorname{ord}(s 2[j-1])) dp[i][j]=min(dp[i1][j]+ord(s1[i1]),dp[i][j1]+ord(s2[j1]),dp[i1][j1]+ord(s1[i1])+ord(s2[j1]))

3. 解决方法

3.1 动态规划方法

  1. 创建一个二维数组 d p d p dp ,大小为 ( m + 1 ) × ( n + 1 ) (m+1) \times(n+1) (m+1)×(n+1) ,其中 m m m n n n 分别是 s 1 s 1 s1 s 2 s 2 s2 的长度。
  2. 初始化边界条件:
    • d p [ i ] [ 0 ] = ∑ k = 0 i − 1 ord ( s 1 [ k ] ) dp[i][0]=\sum_{k=0}^{i-1} \text{ord}(s1[k]) dp[i][0]=k=0i1ord(s1[k]),表示将 s 1 s 1 s1 的前 i i i 个字符转换为空字符串所需删除的 ASCII 值之和。
    • d p [ 0 ] [ j ] = ∑ k = 0 j − 1 ord ( s 2 [ k ] ) dp[0][j]=\sum_{k=0}^{j-1} \text{ord}(s2[k]) dp[0][j]=k=0j1ord(s2[k]),表示将 s 2 s 2 s2 的前 j j j 个字符转换为空字符串所需删除的 ASCII 值之和。
  3. 使用双重石环填充 dp 数组,依赖于前面的状态。
  4. 最终结果为 d p [ m ] [ n ] \mathrm{dp}[\mathrm{m}][\mathrm{n}] dp[m][n]

3.2 空间优化的动态规划

  • 可以使用一维数组来优化空间复杂度,减少内存占用。

4. 进一步优化

通过空间优化,降低内存占用的同时保持时间复杂度为 O ( m ∗ n ) O(m * n) O(mn),适合中等规模的字符串比较。

5. 小总结

  • 最小 ASCII 删除和问题通过动态规划有效地解决了两个字符串之间的转换成本。
  • 该问题的解法展示了如何设计状态转移方程,并且可以通过空间优化提高性能。
  • 理解该问题不仅有助于掌握动态规划的应用,还为处理相似问题提供了思路。

以上就是两个字符串的最小ASCII删除和问题的基本思路。

代码实现

Python

Python3代码实现

class Solution:
    def minimumDeleteSum(self, s1: str, s2: str) -> int:
        m, n = len(s1), len(s2)
        # 创建dp数组
        dp = [[0] * (n + 1) for _ in range(m + 1)]

        # 初始化边界条件
        for i in range(1, m + 1):
            dp[i][0] = dp[i - 1][0] + ord(s1[i - 1])  # 删除s1的字符
        for j in range(1, n + 1):
            dp[0][j] = dp[0][j - 1] + ord(s2[j - 1])  # 删除s2的字符
        
        # 填充dp数组
        for i in range(1, m + 1):
            for j in range(1, n + 1):
                if s1[i - 1] == s2[j - 1]:
                    dp[i][j] = dp[i - 1][j - 1]  # 字符相同
                else:
                    dp[i][j] = min(dp[i - 1][j] + ord(s1[i - 1]),    # 删除s1的字符
                                   dp[i][j - 1] + ord(s2[j - 1]),    # 删除s2的字符
                                   dp[i - 1][j - 1] + ord(s1[i - 1]) + ord(s2[j - 1]))  # 同时删除

        # 返回最小ASCII删除和
        return dp[m][n]

Python 代码解释

  • 初始化:创建 dp 数组并设置边界条件,分别表示将 s1s2 转换为空字符串的操作。
  • 填充 dp 数组:使用双重循环计算每个子问题的最小 ASCII 删除和,依赖于之前的结果。
  • 返回结果:最终返回 dp[m][n],即将 s1 转换为 s2 所需的最小 ASCII 删除和。

C++

C++代码实现

class Solution {
public:
    int minimumDeleteSum(string s1, string s2) {
        int m = s1.size(), n = s2.size();
        // 创建dp数组
        vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0));

        // 初始化边界条件
        for (int i = 1; i <= m; i++) {
            dp[i][0] = dp[i - 1][0] + s1[i - 1];  // 删除s1的字符
        }
        for (int j = 1; j <= n; j++) {
            dp[0][j] = dp[0][j - 1] + s2[j - 1];  // 删除s2的字符
        }
        
        // 填充dp数组
        for (int i = 1; i <= m; i++) {
            for (int j = 1; j <= n; j++) {
                if (s1[i - 1] == s2[j - 1]) {
                    dp[i][j] = dp[i - 1][j - 1];  // 字符相同
                } else {
                    dp[i][j] = min({dp[i - 1][j] + s1[i - 1],    // 删除s1的字符
                                    dp[i][j - 1] + s2[j - 1],    // 删除s2的字符
                                    dp[i - 1][j - 1] + s1[i - 1] + s2[j - 1]});  // 同时删除
                }
            }
        }

        // 返回最小ASCII删除和
        return dp[m][n];
    }
};

C++ 代码解释

  • 初始化:创建 dp 数组并设置边界条件,分别表示将 s1s2 转换为空字符串的操作。
  • 动态规划填充:使用双重循环遍历每个可能的子问题,依据字符是否相同来更新 dp 数组。
  • 返回结果:返回 dp[m][n],即将 s1 转换为 s2 所需的最小 ASCII 删除和。

总结:

  • 最小 ASCII 删除和问题通过动态规划有效地解决了字符串之间的转换成本,具有广泛的实际应用。
  • 理解并掌握该问题的解法,不仅对学习动态规划有帮助,还为处理其他类似问题提供了思路。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2199019.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【已解决】endnote只显示十条文献/licence失效/this license has been suspended

问题&#xff1a;打开endnote后弹窗显示 Were sorry,this license has been suspended due to ...... 关闭弹窗发现只剩10条文献显示了 解决方法&#xff1a; ①关闭杀毒软件 ②找到endnote源文件夹下的License.dat文件&#xff08;找不到的话直接在“此电脑”中搜索&#x…

倒计时3天!飞凌嵌入式邀您共聚第90届CMEF

10月12日~15日&#xff0c;第90届中国国际医疗器械博览会(CMEF)即将在深圳国际会展中心(宝安)隆重举行&#xff0c;4000品牌企业将携数万款产品集中亮相&#xff0c;为全球健康产业带来探析前沿、洞见未来的医疗盛宴。 飞凌嵌入式作为业界领先的嵌入式解决方案提供商&#xff…

七、InnoDB数据存储结构

文章目录 1. 数据库的存储结构:页1.1 磁盘与内存交互基本单位:页1.2 页结构概述1.3 页的大小1.4 页的上层结构2. 页的内部结构2.1 第1部分:File Header(文件头部)和 File Trailer(文件尾部)2.1.1 File Header(文件头部)2.1.2 File tRAILER(文件尾部)2.2 第2部分:Fr…

电商价格监测的创新之路

在当今数字化高速发展的时代&#xff0c;电商如汹涌的浪潮席卷了商业的每一个角落。品牌们在这片广阔的电商海洋中奋力前行&#xff0c;而价格监测则成为了他们手中至关重要的罗盘。 力维网络以其专业的价格监测服务&#xff0c;为品牌在电商之海的航行点亮了一盏明灯。然而&a…

【北京迅为】《STM32MP157开发板嵌入式开发指南》-第二十一章 makefile基本语法(下)

iTOP-STM32MP157开发板采用ST推出的双核cortex-A7单核cortex-M4异构处理器&#xff0c;既可用Linux、又可以用于STM32单片机开发。开发板采用核心板底板结构&#xff0c;主频650M、1G内存、8G存储&#xff0c;核心板采用工业级板对板连接器&#xff0c;高可靠&#xff0c;牢固耐…

韦东山老师linux快速入门otg检测不到方案总结

我是如何解决, 第二节, otg 串口检测不到的, 开发手册链接: https://wwyz.lanzoul.com/iF1TA2c21uoh 我首先按照评论区, 老师说的, 根据完全开发手册, 搜索otg, 然后找到老师当时 烧写系统的时候, 利用usb启动, 然后otg链接, 然后 安装了两个驱动, 往后翻, 就可以翻到 然后重…

多系统数据交换与共享技术方案(医疗行业为例,Doc原件)

目录 1 方案概述 1.1 背景 1.2 参考规范 2 需求分析 2.1 交换内容 2.2 功能需求 1) 消息传输 2) 数据整合 3) 服务集成 4) 流程整合 5) 管理功能 3 总体建设方案 3.1 实现思路 3.1.1 交换方案比选 3.1.2 技术优势 3.2 总体架构 3.3 数据交换与共享基本模型 3.…

ATAM需求说明-系统架构师(七十六)

1体系结构权衡分析法ATAM(Architecture Trade Off Analyzer Method)是一种常见的结构权衡分析法&#xff0c;该框架主要关注系统的&#xff08;&#xff09;&#xff0c;针对性能、安全性、可用性和可修改性&#xff0c;在系统开发前进行分析、评价和这种。 A 需求说明 B 架构…

大型生物制药企业如何实现安全又高效地跨网域数据传输?

大型生物制药企业由于组织结构庞大、业务覆盖研发、生产及销售&#xff0c;因此内部会再细分为多个管理单位&#xff0c;包括研发部门、生产部门、质量控制部门、供应链管理部门及营销部和日常业务支撑部门等。在物理区域划分上&#xff0c;大型生物制药企业会设立实验室、研发…

Java—逻辑控制与输入输出

各位看官&#xff1a;如果您觉得这篇文章对您有帮助的话 欢迎您分享给更多人哦 感谢大家的点赞收藏评论&#xff0c;感谢您的支持&#xff01;&#xff01;&#xff01; 一.顺序结构&#xff1a; 我每天起床&#xff0c;躺在床上玩手机&#xff0c;然后吃中午饭&#xff0c;睡…

[C++ 核心编程]笔记 2 栈区和堆区

栈区: 由编译器自动分配释放&#xff0c;存放函数的参数值,同部变量等 注意事项&#xff1a;不要返回局部变量的地址&#xff0c;栈区开辟的数据由编译器自动释放 #define _CRT_SECURE_NO_WARNINGS 1 #include<iostream> using namespace std;//栈区数据注意事项 不要…

【架构师】系统架构相关知识

本文仅做技术交流&#xff0c;转载请注明来源&#xff0c;切勿商用。 参考&#xff1a;系统架构师考纲及教材 1、系统架构的概念 架构是一种表达&#xff0c;而非可运行的软件。 1&#xff09;分析设计在满足所规定的需求方面的有效性 2&#xff09;在设计变更相对容易的阶段…

【读书笔记·VLSI电路设计方法解密】问题4:今天的设计环境中使用的主要工艺技术是什么

主流的工艺技术是互补金属氧化物半导体&#xff08;CMOS&#xff09;技术。其他技术还包括双极性、双极CMOS&#xff08;biCMOS&#xff09;、绝缘体上硅&#xff08;SOI&#xff09;和砷化镓&#xff08;GaAs&#xff09;。 在CMOS技术中&#xff0c;"互补对称"指的…

Android开发:日志功能备忘

临时记一下吧&#xff0c;以后就直接复制粘贴这里面的好了。 实现一个日志记录程序的运行状态&#xff0c;并且带上时间信息&#xff0c;可以写一个类灵活调用。 MyLog.java package com.example.networkaccessrestrictions;import static android.content.ContentValues.TAG;i…

目标检测实战教程Day1(原创)

原创不易&#xff0c;转载请标明本文地址 目标检测一直是计算机视觉领域的核心问题之一&#xff0c;它就像是让计算机拥有了一双“鹰眼”&#xff0c;能在复杂的图像中迅速锁定和识别出各种有趣的目标&#xff0c;比如人、汽车、动物或者任何其他特定物体。在这一章&#xff0c…

【汇编语言】寄存器(CPU工作原理)(五)—— 段寄存器以及CS和IP

文章目录 前言1. 段寄存器2. CS 和 IP结语 前言 &#x1f4cc; 汇编语言是很多相关课程&#xff08;如数据结构、操作系统、微机原理&#xff09;的重要基础。但仅仅从课程的角度出发就太片面了&#xff0c;其实学习汇编语言可以深入理解计算机底层工作原理&#xff0c;提升代码…

产品推介——AC晶体管光耦KL814

KL814产品系列&#xff0c;由苏州晶台光电有限公司研发生产的一款采用交流输入的晶体管光耦。它结合了两个反向并联的红外发射二极管与一个光电晶体管&#xff0c;构成了一个高效且稳定的光电耦合器。 产品特点Product features ◆交流输入响应 ◆电流传输比 (CTR&#xff1…

vs2022调试cmake工程时,添加命令行参数

第一步&#xff1a; 第二步&#xff1a;在launch.vs.json文件里添加 至此可以在调试当前工程时&#xff0c;可以传入命令行参数。

十款超好用的图纸加密软件推荐!2024企业图纸加密最佳选择!

在企业日常工作中&#xff0c;尤其是制造业、建筑业和设计行业&#xff0c;图纸安全至关重要。图纸泄露可能导致专利技术被盗、商业机密外泄&#xff0c;给公司带来不可估量的损失。为了确保图纸的安全性&#xff0c;图纸加密软件是必不可少的工具。以下是2024年十款超好用的图…

Damerau-Levenshtein算法实现中的错误及更正

在实现 Damerau-Levenshtein 算法 时&#xff0c;常见的错误包括边界条件处理不当、转置操作的遗漏或误用、矩阵初始化错误等。Damerau-Levenshtein 算法是 Levenshtein 编辑距离的扩展&#xff0c;它不仅允许插入、删除和替换&#xff0c;还允许 相邻字符的转置。该算法计算两…