当前位置: 首页 > news >正文

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

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

相关文章:

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

动态规划—712. 两个字符串的最小ASCII删除和 前言题目描述基本思路1. 问题定义2. 理解问题和递推关系3. 解决方法3.1 动态规划方法3.2 空间优化的动态规划 4. 进一步优化5. 小总结 代码实现PythonPython3代码实现Python 代码解释 CC代码实现C 代码解释 总结: 前言 在字符串处…...

wordpress Contact Form 7插件提交留言时发生错误可能的原因

WordPress Contact Form 7 插件提交留言时发生错误可能有以下几种原因&#xff0c;并提供相应的解决方案&#xff1a; 1. 表单字段验证失败 原因&#xff1a; 用户输入的数据未通过表单字段的验证规则。 解决方案&#xff1a; – 检查表单字段的验证规则是否设置正确。 –…...

uibot发送邮件:自动化邮件发送教程详解!

uibot发送邮件的操作指南&#xff1f;uibot发送邮件的两种方式&#xff1f; 在现代办公环境中&#xff0c;自动化流程的引入极大地提高了工作效率。uibot发送邮件功能成为了许多企业和个人实现邮件自动化发送的首选工具。AokSend将详细介绍如何使用uibot发送邮件。 uibot发送…...

【PostgreSQL】PG数据库表“膨胀”粗浅学习

文章目录 1 为什么需要关注表膨胀&#xff1f;2 如何确定是否发生了表膨胀&#xff1f;2.1 通过查询表的死亡元组占比情况来判断膨胀率2.1.1 指定数据库和表名2.1.2 查询数据库里面所有表的膨胀情况 3 膨胀的原理3.1 什么是膨胀&#xff1f;膨胀率&#xff1f;3.2 哪些数据库元…...

力扣(leetcode)每日一题 871 最低加油次数 | 贪心

871. 最低加油次数 题干 汽车从起点出发驶向目的地&#xff0c;该目的地位于出发位置东面 target 英里处。 沿途有加油站&#xff0c;用数组 stations 表示。其中 stations[i] [positioni, fueli] 表示第 i 个加油站位于出发位置东面 positioni 英里处&#xff0c;并且有 f…...

ppt压缩文件怎么压缩?压缩PPT文件的多种压缩方法

ppt压缩文件怎么压缩&#xff1f;当文件体积过大时&#xff0c;分享和传输就会变得困难。许多电子邮件服务对附件的大小有限制&#xff0c;而在网络环境不佳时&#xff0c;上传和下载大文件可能耗时较长。此外&#xff0c;在不同设备上播放时&#xff0c;较大的PPT文件还可能导…...

2024.10月11日--- SpringMVC拦截器

拦截器 1 回顾过滤器&#xff1a; Servlet规范中的三大接口&#xff1a;Servlet接口&#xff0c;Filter接口、Listener接口。 过滤器接口&#xff0c;是Servlet2.3版本以来&#xff0c;定义的一种小型的&#xff0c;可插拔的Web组件&#xff0c;可以用来拦截和处理Servlet容…...

uniapp 锁屏显示插件 Ba-LockShow(可让vue直接具备锁屏显示能力)

简介 Ba-LockShow 是一款可以直接使uniapp的vue界面在锁屏页展示的插件。 支持使vue直接具备锁屏显示能力支持设置锁屏显示和不显示支持唤醒屏幕 截图展示&#xff08;仅参考&#xff09; 支持定制、本地包、源码等&#xff0c;有建议和需要&#xff0c;请点击文章结尾“Unia…...

CSS计数器

CSS 中的计数器类似于变量&#xff0c;可以实现简单的计数功能&#xff0c;并将结果显示在页面上&#xff0c;在早期的网站上应用比较广泛。要实现计数器需要用到以下几个属性&#xff1a; counter-reset&#xff1a;创建或者重置计数器&#xff1b;counter-increment&#xf…...

嵌入式Linux:信号集

目录 1、信号集初始化 2、向信号集中添加或删除信号 3、测试信号是否在信号集中 在 Linux 系统中&#xff0c;处理多个信号时常用到一种数据结构&#xff1a;信号集&#xff08;sigset_t&#xff09;。信号集允许我们将多个信号组织在一起&#xff0c;以便在系统调用中传递和…...

Linux 外设驱动 应用 1 IO口输出

从这里开始外设驱动介绍&#xff0c;这里使用的IMX8的芯片作为驱动介绍 开发流程&#xff1a; 修改设备树&#xff0c;配置 GPIO1_IO07 为 GPIO 输出。使用 sysfs 接口或编写驱动程序控制 GPIO 引脚。编译并测试。 这里假设设备树&#xff0c;已经配置好了。不在论述这个问题…...

基于SpringBoot+Vue+MySQL的留守儿童爱心网站

系统展示 用户前台界面 管理员后台界面 系统背景 随着现代社会的发展&#xff0c;留守儿童问题日益受到关注。传统的纸质管理方式已经无法满足现代人们对留守儿童爱心信息的需求。为了提高留守儿童爱心信息的管理效率&#xff0c;增加用户信息的安全性&#xff0c;并方便及时反…...

调用第三方接口

目录 一、分析给出的接口文档 二、请求体格式之间的区别 三、示例代码 一、分析给出的接口文档 一般的接口文档包括以下几大部分&#xff1a; 1、请求URL&#xff1a;http://{ip}:{port}/api/ec/dev/message/sendCustomMessageSingle 2、请求方式&#xff1a;POST、GET等 3、…...

JAVA 多线程入门例子:CountDownLatch

首先确定线程数量。如果数据集合的大小小于50&#xff0c;就只使用一个线程&#xff1b;否则使用5个线程。计算每个线程平均处理的数据数量sizePerThread以及余数remainder。在划分数据子集合时&#xff0c;对于每个线程的处理范围进行计算。如果有余数&#xff0c;就将余数依次…...

k8s jenkins 动态创建slave

k8s jenkins 动态创建slave 简述使用jenkins动态slave的优势&#xff1a;配置jenkins动态slave配置 Pod Template配置容器模板挂载卷 测试 简述 持续构建与发布是我们日常工作中必不可少的一个步骤&#xff0c;目前大多公司都采用 Jenkins 集群来搭建符合需求的 CI/CD 流程&am…...

MVS海康工业相机达不到标称最大帧率

文章目录 一、相机参数设置1、取消相机帧率限制2、修改相机图像格式3、调整相机曝光时间4、检查相机数据包大小&#xff08;网口相机特有参数&#xff09;5、 恢复相机默认参数6、 相机 ADC 输出位深调整 二、系统环境设置1、 网口相机设置2、 USB 相机设置 一、相机参数设置 …...

数据结构:用双栈实现一个队列

要用两个栈实现一个队列&#xff0c;可以利用“栈”的后进先出 (LIFO) 特性来模拟“队列”的先进先出 (FIFO) 操作。具体做法是使用两个栈&#xff1a;一个作为入栈栈&#xff0c;另一个作为出栈栈。 算法步骤 入队操作&#xff08;enqueue&#xff09;&#xff1a; 将元素压…...

QScroller Class

Header:#include < QScroller > qmake:QT += widgets Since:Qt 5.0 Inherits:QObject This class was introduced in Qt 5.0. Public Types enum Input {InputPress, InputMove, InputRelease } enum ScrollerGestureType {TouchGesture, LeftMouseButtonGesture,…...

React高阶组件详解

React高阶组件&#xff08;HOC&#xff09;详解 定义 React高阶组件&#xff08;HOC&#xff09;是一个函数&#xff0c;该函数接受一个组件作为参数并返回一个新的组件。高阶组件本身不是一个组件&#xff0c;而是一个函数&#xff0c;它利用React的组合特性&#xff0c;对传入…...

TextView把其它控件挤出屏幕的处理办法

1.如果TextView后面的控件是紧挨着TextView的&#xff0c;可以给TextView添加maxWidth限制其最大长度 上有问题的布局代码 <?xml version"1.0" encoding"utf-8"?> <layout xmlns:android"http://schemas.android.com/apk/res/android&qu…...

[STM32U3] 【STM32U385RG 测评】PWM调节屏幕亮度

在评测计划中有使用pwm来实现调节屏幕亮度&#xff0c;因此本篇为如何使用HMI实现对屏的亮度调节。实现原理为&#xff0c;使用TouchGFX Designer添加一个滑动控件&#xff0c;通过滑动来修改pwm的占空比&#xff0c;实现ST7789的BLK的电压实现。 本次工程在上一篇试用的基础上…...

如何高效使用Alas:碧蓝航线自动化智能助手终极指南

如何高效使用Alas&#xff1a;碧蓝航线自动化智能助手终极指南 【免费下载链接】AzurLaneAutoScript Azur Lane bot (CN/EN/JP/TW) 碧蓝航线脚本 | 无缝委托科研&#xff0c;全自动大世界 项目地址: https://gitcode.com/gh_mirrors/az/AzurLaneAutoScript 厌倦了每天重…...

5个关键步骤掌握B站视频下载神器DownKyi:从新手到高手

5个关键步骤掌握B站视频下载神器DownKyi&#xff1a;从新手到高手 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等&#…...

Windows 11终极优化指南:使用Win11Debloat实现专业级系统调校

Windows 11终极优化指南&#xff1a;使用Win11Debloat实现专业级系统调校 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter…...

LongWriter实战教程:从零开始构建你的专属写作AI

LongWriter实战教程&#xff1a;从零开始构建你的专属写作AI 【免费下载链接】LongWriter [ICLR 2025] LongWriter: Unleashing 10,000 Word Generation from Long Context LLMs 项目地址: https://gitcode.com/gh_mirrors/lo/LongWriter LongWriter是一款基于长上下文L…...

从“会响”到“可靠”:给这个经典12V降5V电路加个二极管和电容,稳定性提升不止一点点

从“会响”到“可靠”&#xff1a;经典12V降5V电路的稳定性优化实战 当你在面包板上搭建好那个经典的稳压管NPN降压电路&#xff0c;看着万用表显示稳定的5V输出时&#xff0c;或许会感到一丝成就感。但当你接上负载&#xff0c;发现电压开始波动&#xff0c;或者在电源反接时闻…...

Ubuntu 16.04 32位系统下RT-Thread开发环境搭建全攻略

1. 项目概述&#xff1a;为何要重温一个“过时”的旧系统环境&#xff1f;如果你在2024年看到这个标题&#xff0c;第一反应可能是&#xff1a;“Ubuntu 16.04&#xff1f;还是32位&#xff1f;这都什么年代的配置了&#xff0c;现在不都用Ubuntu 22.04或者24.04了吗&#xff1…...

实测!Gemini+ChatGPT赋能学术写作:我的论文写作SOP(附提示词)

各位同仁好,我是七哥。一个在高校里从事人工智能相关领域研究,钻研用大模型AI实操的学术人。可以和七哥交流学术写作或Gemini、GPT、Claude等大模型学术实操相关问题,多多交流,相互成就,共同进步。 为什么ChatGPT逻辑清晰却写不长?为什么Gemini能深入分析但废话连篇? …...

B站缓存视频无损转换终极指南:3步快速上手m4s-converter开源工具

B站缓存视频无损转换终极指南&#xff1a;3步快速上手m4s-converter开源工具 【免费下载链接】m4s-converter 一个跨平台小工具&#xff0c;将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否曾为B站缓存视…...

RK3588 LGA核心板:高性能嵌入式开发的模块化解决方案

1. 项目概述&#xff1a;当旗舰SoC遇见极致封装最近在嵌入式圈子里&#xff0c;一个“小而强”的组合引起了我的注意&#xff1a;瑞芯微的旗舰级SoC RK3588&#xff0c;被塞进了一个极其紧凑的LGA封装里&#xff0c;做成了名为SOM-3588-LGA的核心板&#xff0c;并且已经现货发售…...