算法-字符串-72.编辑距离

一、题目

二、思路解析

1.思路:

最少操作数------动态数组

res[i][j]:长度为i的字符串转化为长度为j字符串的最少操作

2.常用方法:

3.核心逻辑:

1.情况一:当word1为空,word2不为空时

java 复制代码
for(int i=0;i<=size2;i++){
    res[0][i]=i;
}

2.情况二:word1不为空,word2为空时

java 复制代码
for(int i=0;i<=size1;i++){
    res[i][0]=i;
}

3.情况三:word1和word2都不为空

a.如果当前二者轮询到的字符是相等的,那么res[i][j]=res[i-1][j-1](两个字符串前一位的一致的最小操作数)

java 复制代码
if(word1.charAt(i-1)==word2.charAt(j-1)){
    res[i][j]=res[i-1][j-1];
}

b.若当前二者轮询的字符是不相等的,那么来源有2个:

1.字符串都删除当前字符,即res[i-1][j-1]

2.有其中一个字符串删除当前字符 res[i-1][j]或res[i][j-1]

java 复制代码
else {
                    res[i][j]=Math.min(res[i-1][j-1],Math.min(res[i-1][j],res[i][j-1]))+1;
                }

三、代码实现

java 复制代码
class Solution {
    public int minDistance(String word1, String word2) {
        int size1=word1.length();
        int size2=word2.length();

        int[][]res=new int[size1+1][size2+1];

        //初始化1.word1为空字符串时,需要经过word2的长度次数才能转化成功
        for(int i=1;i<=size2;i++){
            res[0][i]=i;
        }

        //初始化2:word2为空字符串时。需要经过word1的长度次数才能转化成功
        for(int i=1;i<=size1;i++){
            res[i][0]=i;
        }

        for(int i=1;i<=size1;i++){
            for(int j=1;j<=size2;j++){
                if(word1.charAt(i-1)==word2.charAt(j-1)){
                    res[i][j]=res[i-1][j-1];
                }else{
                    res[i][j]=Math.min(res[i-1][j-1],Math.min(res[i-1][j],res[i][j-1]))+1;
                }
            }
        }
        return res[size1][size2];
    }
}
相关推荐
李菠菜5 分钟前
非SpringBoot环境下Jedis集群操作Redis实战指南
java·redis
不当菜虚困17 分钟前
JAVA设计模式——(四)门面模式
java·开发语言·设计模式
BB_CC_DD21 分钟前
四. 以Annoy算法建树的方式聚类清洗图像数据集,一次建树,无限次聚类搜索,提升聚类搜索效率。(附完整代码)
深度学习·算法·聚类
m0Java门徒25 分钟前
面向对象编程核心:封装、继承、多态与 static 关键字深度解析
java·运维·开发语言·intellij-idea·idea
无心水1 小时前
【Java面试笔记:基础】8.对比Vector、ArrayList、LinkedList有何区别?
java·笔记·面试·vector·arraylist·linkedlist
创码小奇客1 小时前
MongoDB 时间序列:解锁数据时光机的终极指南
java·mongodb·trae
黯_森1 小时前
Java面向对象
java·后端
代码小侦探1 小时前
Java中以Maven方式引入Oracle JDBC Driver依赖的详解
java·oracle·maven
不畏惧的少年1 小时前
AQS的底层实现原理
java
洛小豆2 小时前
饭票、图书馆、GC:这样理解 Java 引用,谁还不会?
java·后端·面试