【代码随想录算法训练营第五十一天|115.不同的子序列、583. 两个字符串的删除操作、72.编辑距离】

文章目录

115.不同的子序列

dp数组表示s和t中前i-1j-1项中s中出现过的t的次数,递推公式中当选择到s的第i-1的元素和tj-1相等时,需要考虑两种情况,第一种是选择用si-1这个元素和tj-1匹配,那么dpij就应该是dpi-1j-1,如果不使用si-1的话,就应该是和dpi-1j相同,因此dp[i][j] = dp[i-1][j-1] + dp[i-1][j]。当si-1不等于tj-1时,就相当于是不使用si-1和t:j匹配的情况,因此赋值为dpi-1j

python 复制代码
class Solution:
    def numDistinct(self, s: str, t: str) -> int:
        len1 = len(s)
        len2 = len(t)
        dp = [[0]* (len2+1) for _ in range(len1+1)] # dp[i][j] 前一位是s后一位是t,t不变在s中删减,当t=''的时候dp[i][0]应该为1 
        for d in dp:
            d[0] = 1
        for i in range(1, len1+1):
            for j in range(1, len2+1):
                if s[i-1] == t[j-1]:
                    dp[i][j] = dp[i-1][j-1] + dp[i-1][j]
                else:
                    dp[i][j] = dp[i-1][j]
        return dp[-1][-1]

583. 两个字符串的删除操作

其实就是找两个数组相同的公共子序列长度,最后输出的时候拿两个数组的长度和减去两倍的最大公共子序列长度就可以。

python 复制代码
class Solution:
    def minDistance(self, word1: str, word2: str) -> int:
        len1 = len(word1)
        len2 = len(word2)
        dp = [[0]*(len2+1) for _ in range(len1+1)] # dp[i][j]表示word1选择前i位,word2选择前j位的时候两个字符串相同字符的个数
        for i in range(1, len1+1):
            for j in range(1, len2+1):
                if word1[i-1] == word2[j-1]:
                    dp[i][j] = dp[i-1][j-1] + 1
                else:
                    dp[i][j] = max(dp[i-1][j], dp[i][j-1])
        return len1 + len2 - 2*dp[-1][-1]

72.编辑距离

本质上还是在找两个字符串的最长相同子序列,这里的增加操作和删除操作其实可以看作是同一种操作,只是在两个字符串上反过来,因此需要增加一个字符也可以看作是另一个字符种删除掉这个字符,所以当word1和word2的字符i和j不相等的时候,dpij在dpi-1j即删除word1元素,dpij-1即删除word2元素,和dpi-1j-1即替换元素中选择最小的,然后+1。还有一个重要的是初始dp的时候需要对所有一个为空另一个不为空的时候的dp赋予初值,初值就是那个字符串的长度。

python 复制代码
class Solution:
    def minDistance(self, word1: str, word2: str) -> int:
        len1 = len(word1)
        len2 = len(word2)
        dp =[[0] * (len2+1) for _ in range(len1+1)]
        for i in range(len1+1):
            dp[i][0] = i
        for j in range(len2+1):
            dp[0][j] = j
        for i in range(1, len1+1):
            for j in range(1, len2+1):
                if word1[i-1] == word2[j-1]:
                    dp[i][j] = dp[i-1][j-1]
                else:
                    dp[i][j] = min(dp[i-1][j], dp[i][j-1], dp[i-1][j-1]) + 1
        return dp[-1][-1]
相关推荐
通信小呆呆1 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
benben0441 天前
强化学习之DQN算法族(基于gymnasium开发)
算法
何以解忧,唯有..2 天前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
想吃火锅10052 天前
【leetcode】88.合并两个有序数组js
算法
生成论实验室2 天前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Qres8212 天前
算法复键——树状数组
数据结构·算法
H178535090962 天前
SolidWorks第四部分_直接实体建模特征9_替换面原理
线性代数·算法·机器学习·3d建模·solidworks
不会就选b2 天前
算法日常・每日刷题--<二分查找>3
算法
绿算技术2 天前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?
科技·算法·架构