【Hot100】LeetCode—72. 编辑距离

目录

  • [1- 思路](#1- 思路)
  • [2- 实现](#2- 实现)
    • [⭐++72. 编辑距离++------题解思路](#⭐72. 编辑距离——题解思路)
  • [3- ACM 实现](#3- ACM 实现)


1- 思路

题目识别

  • 识别1 :两个字符串之间相互转换,增、删、替换 最少的操作次数

动规五部曲

  • 1- 定义 dp 数组
    • dp[i][j] 代表,长度为 i-1nums1 和长度为 j-1nums2 的编辑距离,也就是使二者相等的最小操作次数
  • 2- 递推公式
    • 如果两个字符相同了dp[i][j] = dp[i-1][j-1],因为相同所以不需要任何操作
    • 否则
      • 删除 word1 操作:dp[i-1][j] + 1
      • 删除 word2 操作:dp[i][j-1] + 1
      • 替换操作:dp[i-1][j-1] + 1
    • 因此 dp[i][j] = Math.min(dp[i-1][j] + 1,Math.min(dp[i][j-1]+1,dp[i-1][j-1]+1);
  • 3- 初始化
    • 第一行、第一列初始化为对应的下标。
    • i1 遍历到 len1 比如 dp[i][0] 则初始化为i
  • 4- 递推
    • 由于 [i][j] 根据 [i-1][j-1]来,所以从上到下,从左到右遍历

2- 实现

⭐++72. 编辑距离++------题解思路

java 复制代码
    public int minDistance(String word1, String word2) {
        // 1. 定义dp数组
        int[][] dp = new int[word1.length() + 1][word2.length() + 1];

        // 2.递推公式
        // 相等 dp[i][j] = dp[i-1][j-1];
        // 不相等 dp[i][j] = Math.min(dp[i-1]+1,dp[i-1][j-1]+1);

        // 3.初始化
        for (int i = 0; i <= word1.length(); i++) {
            dp[i][0] = i;
        }
        for (int j = 0; j <= word2.length(); j++) {
            dp[0][j] = j;
        }

        // 4.遍历
        for (int i = 1; i <= word1.length(); i++) {
            for (int j = 1; j <= word2.length(); j++) {
                if (word2.charAt(j - 1) == word1.charAt(i - 1)) {
                    dp[i][j] = dp[i - 1][j - 1];
                } else {
                    dp[i][j] = Math.min(dp[i - 1][j] + 1, Math.min(dp[i][j - 1] + 1, dp[i - 1][j - 1] + 1));
                }
            }
        }
        return dp[word1.length()][word2.length()];
    }

3- ACM 实现

java 复制代码
public class minDistance {

    public static int minDistance(String word1,String word2){
        // 1.定义dp
        // dp[i][j] 代表 以 i-1 和 j-1 为结尾的 word1 和 word2 的编辑距离
        int len1 = word1.length();
        int len2 = word2.length();
        int[][] dp = new int[len1+1][len2+1];

        // 2.递推公式
        // 相等的话 dp[i][j] = dp[i-1][j-1]
        // 不相等 删除两种 dp[i-1][j]+1,dp[i][j-1]+1,dp[i-1][j-1]+1

        // 3.初始化
        //
        for(int i = 1 ; i <= len1 ;i++){
            dp[i][0] = i;
        }
        for(int i = 1 ; i <= len2;i++){
            dp[0][i] = i;
        }

        for(int i = 1 ; i <= len1;i++){
            for(int j = 1 ; j <= len2;j++){
                if(word1.charAt(i-1) == word2.charAt(j-1)){
                    dp[i][j] = dp[i-1][j-1];
                }else{
                    dp[i][j] = Math.min(dp[i-1][j]+1,Math.min(dp[i][j-1]+1,dp[i-1][j-1]+1));
                }
            }
        }
        return dp[len1][len2];
    }


    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String word1 = sc.nextLine();
        String word2 = sc.nextLine();
        System.out.println("结果是"+minDistance(word1,word2));
    }
}
相关推荐
聚客AI16 小时前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v19 小时前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工21 小时前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农1 天前
【React用到的一些算法】游标和栈
算法·react.js
博笙困了1 天前
AcWing学习——双指针算法
c++·算法
moonlifesudo1 天前
322:零钱兑换(三种方法)
算法
NAGNIP2 天前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
美团技术团队2 天前
LongCat-Flash:如何使用 SGLang 部署美团 Agentic 模型
人工智能·算法
Fanxt_Ja2 天前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
侃侃_天下2 天前
最终的信号类
开发语言·c++·算法