算法随想录算法训练营第四十六天| 583. 两个字符串的删除操作 72. 编辑距离

news/2024/7/24 9:10:41 标签: 算法, leetcode, 职场和发展

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

题目:给定两个单词 word1 和 word2 ,返回使得 word1 和  word2 相同所需的最小步数。

每步 可以删除任意一个字符串中的一个字符。

思路:这题思路主要是求出 word1 字符串和 word2 字符串中的最长相同的子字符串(比如“abc”子字符串为“a”,“b”,“c”,“ab”,“ac”,“bc”,“abc”);求出最长相同的字符串之后,用两个字符串的长度和减去两倍的最长相同子字符串就是我们需要求得长度。 

class Solution {
    public int minDistance(String word1, String word2) {
        int len1 = word1.length();
        int len2 = word2.length();
        int[][] dp = new int[len1+1][len2+1];
        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]+1;
                }else{
                    dp[i][j] = Math.max(dp[i-1][j],dp[i][j-1]);
                }
            }
        }
        return len1+len2-2*dp[len1][len2];
    }
}

72. 编辑距离 

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

你可以对一个单词进行如下三种操作:

  • 插入一个字符
  • 删除一个字符
  • 替换一个字符
class Solution {
    public int minDistance(String word1, String word2) {
  int len1 = word1.length();
        int len2 = word2.length();
        int dp[][] = new int[len1 + 1][len2 + 1];
        //初始化
        for (int i = 0; i <= len1; i++) {
            dp[i][0] = i;
        }
        for (int i = 0; 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], Math.min(dp[i][j - 1], dp[i - 1][j - 1])) + 1;//三种情况,分别代表dp[i][j - 1]:增加一个元素,dp[i - 1][j]:删除一个元素, dp[i - 1][j - 1]修改一个元素
            }
        }
        return dp[len1][len2];
    }
}

 


http://www.niftyadmin.cn/n/5132567.html

相关文章

好题分享(2023.10.22——2023.10.28)

目录 ​编辑 前言&#xff1a; 题目一&#xff1a;《消失的数字》 1.先排序再遍历 2.异或 3.等差数列求和&#xff0c;再相减 题目二&#xff1a;《轮转数组》 1.开辟新的数组 2.原地逆序 题目三&#xff1a;《移除元素》 题目四&#xff1a;《删除有序数组的重复项…

Springboot项目Eureka安全加密

一、通过security增加账号密码登录 1、registry服务pom增加security依赖 2、registry 配置文件 指定security账号密码 3、http://账号:密码IP:PORT/eureka/ 4、重启 二、关闭节点 三、防火墙移除eureka端口访问 参考&#xff1a;Linux(Centos7)操作记录

mysql - <choose>多条件判断 (等同于switch,case,default)

使用介绍 choose 标签作用是通过条件判断来拼接 SQL 语句&#xff0c;类似于 Java 中的 switch 语句&#xff0c;从上到下&#xff0c;当有匹配的条件时&#xff0c;跳出 choose 语句&#xff1b;如果所有条件都不成立则执行 otherwise 标签中的内容 注意最先需要判断的条件要…

虚机Centos忘记密码如何重置

1进入开机前的页面&#xff0c;选中第一个&#xff0c;按“e”键&#xff0c;进入编辑模式 2找到ro crashkernel项&#xff0c;将ro替换成 rw initsysroot/bin/sh 3 Ctrlx mount -o remount, rw / chroot /sysroot chroot /sysroot passwd root 输入两次密码 touch /.a…

​Vue2响应式原理

目录 初始化 initProps()&#xff1a;父组件传的 props 列表&#xff0c;proxy() 把属性代理到当前实例上 vm._props.xx 变成 vm.xx initData()&#xff1a;判断data和props、methods是否重名&#xff0c;proxy() 把属性代理到当前实例上 this.xx observe()&#xff1a;给…

Docker容器内ubuntu更新apt-get 国内加速

Docker容器内ubuntu更新apt-get 国内加速 前言具体办法 前言 由于不使用国内镜像网速缓慢&#xff0c;所以使用国内镜像加速就很必要了&#xff0c;但是经过博主测试大部分apt-get加速都是针对Ubuntu 的&#xff0c;根本解决不了Docker 容器内 apt-get 加速问题。 进过博主反复…

【Java之家-编程的衣柜】操作系统(1)

操作系统&#xff08;Operating System&#xff09; 操作系统是一组做计算机资源管理的软件的统称。目前常见的操作系统有&#xff1a;Windows系列、Unix系列、Linux系列、OSX系列、Android系列、iOS系列、鸿蒙等。 操作系统的定位 操作系统由两个基本功能&#xff1a; 防止硬…

数据特征工程 | 基于PCA算法(Python)

随着数据量的不断增加和数据维度的不断扩展,如何进行高效的数据降维处理成为了一个热门话题。在数据分析领域,PCA算法作为一种常用的数据降维方法,可以对多个特征进行降维,提高计算效率和降低存储空间需求。本文以波士顿房价数据集为例,探讨如何利用PCA算法对房屋价格进行…