代码随想录算法训练营第四十五天|动态规划part12

115.不同的子序列

题目链接:115. 不同的子序列 - 力扣(LeetCode)

文章讲解:代码随想录

定义dp[i][j]表示 s 0-i-1与t 0-j-1不同的子序列的个数

以s=batgtg t=bag为例子

s【4】!=t【3】

所以dp[5][4]=dp[4][4] 也就是不考虑s[4]

继续往后

s[5]==t[3]

也就是s[5]跟t【3】配对上了

batgt 与bag配对的个数加上 batgt与ba配对的个数

dp[6][4]=dp[5][4]+dp[5][3]

错误解答:

cpp 复制代码
class Solution {
public:
    int numDistinct(string s, string t) {
        vector<vector<int>>dp(s.size()+1,vector<int>(t.size()+1,0));
        for(int i=1;i<s.size();i++){
            for(int j=1;j<t.size();j++){
                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[s.size()][t.size()];
        
    }
};

上面算出来的结果都是0,原因是错误地初始化。

正确解答:

cpp 复制代码
class Solution {
public:
    int numDistinct(string s, string t) {
        vector<vector<unsigned int>>dp(s.size()+1,vector<unsigned int>(t.size()+1,0));
        for(int i=0;i<s.size();i++){
            dp[i][0]=1;
        }
        for(int j=0;j<t.size();j++){
            dp[0][j]=0;
        }
        dp[0][0]=1;
        for(int i=1;i<=s.size();i++){
            for(int j=1;j<=t.size();j++){
                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[s.size()][t.size()];
        
    }
};

int 32位

long 64位

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

题目链接:583. 两个字符串的删除操作 - 力扣(LeetCode)

文章讲解:代码随想录

思路:

1.定义dp数组定义

dp[i][j]表示使以i-1结尾的word1和以j-1为结尾的word2相同所需要的删除步骤

2.状态转移方程

if(word1[i-1]==word2[j-1]){

dp[i][j]=dp[i-1][j-1] //不同考虑这两个字母

}else{

int a=min(dp[i-1][j]+1,dp[i][j-1]+1) //删除word1或word2

dp[i][j]=min(a,dp[i-1][j-1]+2) //两个都删除

}

3.初始化dp[i][0]与dp[0][j]

dp[i][0]=i;

dp[0][j]=j;

dp[0][0]=0;

4.遍历顺序 正序遍历

cpp 复制代码
class Solution {
public:
    int minDistance(string word1, string word2) {
        vector<vector<int>>dp(word1.size()+1,vector<int>(word2.size()+1,0));
        for(int i=0;i<=word1.size();i++){
            dp[i][0]=i;
        }
        for(int j=0;j<=word2.size();j++){
            dp[0][j]=j;
        }
        for(int i=1;i<=word1.size();i++){
            for(int j=1;j<=word2.size();j++){
                if(word1[i-1]==word2[j-1]){
                    dp[i][j]=dp[i-1][j-1]  ; //不同考虑这两个字母
                }else{
                    int a=min(dp[i-1][j]+1,dp[i][j-1]+1);
                dp[i][j]=min(a,dp[i-1][j-1]+2)    ;   //两个都删除
                }
            }
        }
        return dp[word1.size()][word2.size()];
    }
};

72. 编辑距离

题目链接:72. 编辑距离 - 力扣(LeetCode)

文章讲解:代码随想录

cpp 复制代码
class Solution {
public:
    int minDistance(string word1, string word2) {
        vector<vector<int>>dp(word1.size()+1,vector<int>(word2.size()+1,0));
        //定义dp【i】【j】word1以i-1结尾word2以j-1结尾的最少操作数
        for(int i=0;i<=word1.size();i++){
            dp[i][0]=i;
        }
        for(int j=0;j<=word2.size();j++){
            dp[0][j]=j;
        }
        for(int i=1;i<=word1.size();i++){
             for(int j=1;j<=word2.size();j++){
                if(word1[i-1]==word2[j-1]){
                    dp[i][j]=dp[i-1][j-1];//不操作
                }else{
                    int erase=min(dp[i-1][j]+1,dp[i][j-1]+1);//删除或增加
                    dp[i][j]=min(erase,dp[i-1][j-1]+1) ;      //替换
                }
            }
        }
        return dp[word1.size()][word2.size()];
        
    }
};

动态规划解这个太棒了

关键是递推公式的推导。

相关推荐
天若有情67321 小时前
TFword:从字符到片段,解析一个“小而精”的字符串处理工具的设计智慧
java·jvm·算法
DuHz21 小时前
频率分集阵列雷达——论文阅读
论文阅读·算法·汽车·信息与通信·毫米波雷达
机器学习之心21 小时前
198种组合算法+优化RF随机森林+SHAP分析+新数据预测!机器学习可解释分析,强烈安利,粉丝必备!
算法·随机森林·机器学习·shap分析·198种组合算法
jikiecui1 天前
信奥崔老师:实数型: float、double
c++·算法
知花实央l1 天前
【数字逻辑】数字逻辑实验实战:74HC151实现逻辑函数+74HC138搭全加器(附接线步骤+避坑指南)
算法·容器·测试用例·逻辑回归
CoovallyAIHub1 天前
突破性开源模型DepthLM问世:视觉语言模型首次实现精准三维空间理解
深度学习·算法·计算机视觉
WaWaJie_Ngen1 天前
【OpenGL】模板测试(StencilTest)
c++·算法·游戏·游戏引擎·游戏程序·图形渲染
Yuroo zhou1 天前
破空驭风,智领未来 --5KG物流配送无人机展示飞行!
人工智能·算法·机器人·硬件工程·无人机
CoovallyAIHub1 天前
ICCV 2025 最佳论文出炉:CMU 团队用「AI 积木大师」BrickGPT 摘得桂冠!
深度学习·算法·计算机视觉