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

陵水网站建设品牌网络营销策划

陵水网站建设,品牌网络营销策划,重庆大足网站制作公司推荐,商城手机网站建设动态规划—712. 两个字符串的最小ASCII删除和 前言题目描述基本思路1. 问题定义2. 理解问题和递推关系3. 解决方法3.1 动态规划方法3.2 空间优化的动态规划 4. 进一步优化5. 小总结 代码实现PythonPython3代码实现Python 代码解释 CC代码实现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 删除和问题通过动态规划有效地解决了字符串之间的转换成本,具有广泛的实际应用。
  • 理解并掌握该问题的解法,不仅对学习动态规划有帮助,还为处理其他类似问题提供了思路。
http://www.dinnco.com/news/49937.html

相关文章:

  • 做网站需要哪些素材短视频平台推广
  • 做像淘宝网的网站中国知名网站排行榜
  • 站长之家ip查询工具seo一个月赚多少钱
  • wordpress管理员权限获取西藏自治区seo 标题 关键词优化
  • dw做框架网站中国十大软件外包公司
  • 不用写代码做网站上海网络推广营销策划方案
  • 吉林省 网站建设最新军事新闻今日最新消息
  • 网站建设 制作教程 pdf营销型网站建设需要多少钱
  • 哪个网站可以做房产信息群发网站推广优化方法
  • 培训机构网站源码成品网站1688入口网页版
  • 人像摄影网站百度关键词推广方案
  • 做设计必知网站网络营销的基本功能
  • 天津艺匠做网站防晒霜营销软文
  • 导航网站超链接如何做百度权重批量查询
  • 怎么看网站是哪个平台做的宁波网站建设团队
  • 网站排名快速上升seo搜索引擎优化排名哪家更专业
  • 自己开个网站多少钱百度的电话人工客服电话
  • 少儿类网站怎么做花生壳免费域名注册
  • 网站建设价钱最近一周新闻大事摘抄
  • 印刷设计营销网站百度网站打不开
  • 宿迁网站建设价格seo有哪些优化工具
  • 学做投资网站好广告投放渠道有哪些
  • 网站导航栏是什么郑州seo代理外包公司
  • 做网站有哪些软件苏州网站建设哪家靠谱
  • 无锡建设主管部门网站天津seo网络
  • 展示型网站有哪些站内推广方式有哪些
  • 个人网站备案如何取名称百度推广手机app下载
  • 西安模板网站建设套餐佛山网站搜索排名
  • 加强学科网站建设网站推广的概念
  • 网站建设与维护工资重庆网站seo服务