@ 代码随想录算法训练营第8周(C语言)|Day59(动态规划)

@ 代码随想录算法训练营第8周(C语言)|Day59(动态规划)

Day59、动态规划(包含题目 ● 583. 两个字符串的删除操作 ● 72. 编辑距离 )

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

题目描述

给定两个单词 word1 和 word2,找到使得 word1 和 word2 相同所需的最小步数,每步可以删除任意一个字符串中的一个字符。

c 复制代码
int minDistance(char* word1, char* word2) {
    int word1num=strlen(word1);
    int word2num=strlen(word2);
    int dp[word1num+1][word2num+1];
    for(int i=0;i<word1num+1;i++){
        dp[i][0]=i;
    }
    for(int j=0;j<word2num+1;j++){
        dp[0][j]=j;
    }
    for(int i=1;i<word1num+1;i++){
        for(int j=1;j<word2num+1;j++){
            if(word1[i-1]==word2[j-1]){
                dp[i][j]=dp[i-1][j-1];
            }else{
                dp[i][j]=fmin(dp[i-1][j]+1,dp[i][j-1]+1);
            }
        }
    }
    return dp[word1num][word2num];
}

题目总结

dp[i][j]:以i-1为结尾的字符串word1,和以j-1位结尾的字符串word2,想要达到相等,所需要删除元素的最少次数。这是只有删除操作的时候。

72. 编辑距离

题目描述

给你两个单词 word1 和 word2,请你计算出将 word1 转换成 word2 所使用的最少操作数 。

题目解答

c 复制代码
int minDistance(char* word1, char* word2) {
    int word1num=strlen(word1);
    int word2num=strlen(word2);
    int dp[word1num+1][word2num+1];
    for(int i=0;i<word1num+1;i++){
        dp[i][0]=i;
    }
    for(int j=0;j<word2num+1;j++){
        dp[0][j]=j;
    }
    for(int i=1;i<word1num+1;i++){
        for(int j=1;j<word2num+1;j++){
            if(word1[i-1]==word2[j-1]){
                dp[i][j]=dp[i-1][j-1];
            }else{
                dp[i][j]=fmin(dp[i-1][j],fmin(dp[i][j-1],dp[i-1][j-1]))+1;
            }
        }
    }
    return dp[word1num][word2num];
}

题目总结

包含插入替换操作之后的编辑距离问题。

相关推荐
liu****21 分钟前
10.排序
c语言·开发语言·数据结构·c++·算法·排序算法
_OP_CHEN29 分钟前
【算法基础篇】(三十二)动态规划之背包问题扩展:从多重到多维,解锁背包问题全场景
c++·算法·蓝桥杯·动态规划·背包问题·算法竞赛·acm/icpc
listhi52032 分钟前
机械系统运动学与动力学在MATLAB及SimMechanics中的实现方案
人工智能·算法·matlab
fufu031133 分钟前
Linux环境下的C语言编程(三十九)
c语言·数据结构·算法·链表
炽烈小老头34 分钟前
【 每天学习一点算法 2025/12/12】回文链表
学习·算法·链表
前端小L34 分钟前
回溯算法专题(十):二维递归的完全体——暴力破解「解数独」
数据结构·算法
云qq1 小时前
x86操作系统19——键盘驱动
linux·c语言·汇编
AI科技星1 小时前
姬无烦科幻与张祥前统一场论的完美融合
数据结构·人工智能·算法·机器学习·重构
comli_cn1 小时前
Adam算法
人工智能·算法·机器学习
另寻沧海1 小时前
C++ Lambda表达式的隐式转换陷阱
java·c++·算法