leetcode 字符串

1143. 最长公共子序列 

. - 力扣(LeetCode)

class Solution {
public:
    int longestCommonSubsequence(string text1, string text2) {
        int m=text1.length();
        int n=text2.length();
        vector<vector<int>>f(m+1,vector<int>(n+1,0));
        
        
        for(int i=1;i<=m;i++){
            for(int j=1;j<=n;j++){
                if(text1[i-1]==text2[j-1])
                    f[i][j] = f[i-1][j-1]+1;
                else
                    f[i][j]= max(f[i-1][j], f[i][j-1]);
            }
        }
        return f[m][n];

    }
};

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

. - 力扣(LeetCode)

方法一:先算出最长公共子序列,在分别(word1.length - f[m][n])+ (word2.length-f[m][n]);

class Solution {
public:
    int minDistance(string word1, string word2) {
        int m=word1.length();
        int n=word2.length();
        vector<vector<int>> f(m+1,vector<int>(n+1, 0));
        for(int i=1;i<=m;i++){
            for(int j=1;j<=n;j++){
                if(word1[i-1]==word2[j-1])
                    f[i][j] = f[i-1][j-1]+1;
                else
                    f[i][j] = max(f[i-1][j], f[i][j-1]);
            }
        }
        return m+n-2*f[m][n];
    }
};

方法二:直接定义f[i][j]:word1[0;i]和word2[0:j]变成一样的最小删除次数。

class Solution {
public:
    int minDistance(string word1, string word2) {
        int m=word1.length();
        int n=word2.length();
        vector<vector<int>> f(m+1,vector<int>(n+1,0));
        for(int i=0;i<=m;i++)
            f[i][0] = i;
        for(int j=0;j<=n;j++)
            f[0][j] = j;

        for(int i=1;i<=m;i++){
            for(int j=1;j<=n;j++){
                if(word1[i-1]==word2[j-1])
                    f[i][j] = f[i-1][j-1];
                else
                    f[i][j] = min(f[i-1][j], f[i][j-1])+1;
                
            }
        } 
        return f[m][n];
    }
};

相关推荐

  1. leetcode 字符串

    2024-06-16 19:28:02       30 阅读
  2. leetcode 字符串相关题目

    2024-06-16 19:28:02       53 阅读
  3. LeetCode-394.字符串解码】

    2024-06-16 19:28:02       42 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-16 19:28:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-16 19:28:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-06-16 19:28:02       87 阅读
  4. Python语言-面向对象

    2024-06-16 19:28:02       96 阅读

热门阅读

  1. 11.NiO多线程优化

    2024-06-16 19:28:02       34 阅读
  2. 使用Elasticsearch在同一索引中区分不同类型的文档

    2024-06-16 19:28:02       36 阅读
  3. make menuconfig | allyesconfig | allnoconfig【笔记】

    2024-06-16 19:28:02       31 阅读
  4. Verilog-学习verilog中遇到的问题总结

    2024-06-16 19:28:02       30 阅读
  5. 洛谷 AT_arc168_a [ARC168A] <Inversion> 题解

    2024-06-16 19:28:02       35 阅读
  6. 用户组的概念(linux篇)

    2024-06-16 19:28:02       27 阅读
  7. CentOS下 conda环境设置

    2024-06-16 19:28:02       28 阅读
  8. HTTP!!!

    HTTP!!!

    2024-06-16 19:28:02      34 阅读
  9. Android基础-ANR详解

    2024-06-16 19:28:02       32 阅读