代码随想录算法训练营Day55|LC392 判断子序列LC115 不同的子序列LC583 两个字符串的删除操作

本文主要是介绍代码随想录算法训练营Day55|LC392 判断子序列LC115 不同的子序列LC583 两个字符串的删除操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一句话总结:115有点难想转移方程。

原题链接:392 判断子序列

题比较简单,dp方法不做一一分析,代码如下:

class Solution {public boolean isSubsequence(String s, String t) {int m = s.length(), n = t.length();int[][] dp = new int[m + 1][n + 1];for (int i = 1; i <= m; ++i) {for (int j = 1; j <= n; ++j) {if (s.charAt(i - 1) == t.charAt(j - 1)) dp[i][j] = dp[i - 1][j - 1] + 1;else dp[i][j] = dp[i][j - 1];}}return dp[m][n] == m ? true : false;}
}

 

原题链接: 115 不同的子序列

 

本题较难。按dp五部曲分析如下:

  1. 确定dp数组及下标的含义:以s[i - 1]结尾的s子序列中出现的以t[j - 1]为结尾的t的子序列的个数;
  2. 确定状态转移方程:s[i - 1] == t[j - 1]时,dp[i][j]由两种情况的和而来:即dp[i][j] = dp[i - 1][j - 1] + dp[i - 1][j],s[i - 1] != t[j - 1]时,dp[i][j]则只有一种转移情况:dp[i][j] = dp[i - 1][j];
  3. dp数组的初始化:对于dp[i][0],由于t的空串为任意字符串的子序列,因此dp[i][0]= 1。同时,对于dp[0][j](0 < j < n),由于s的空串除空串外不可能有任何子序列,因此dp[0][j] = 0;
  4. 确定遍历顺序:从上面方程的推导过程来看,一定是从上往下从左往右的;
  5. 举例推导:略。

以下是代码:

class Solution {static final int MOD = (int) 1e9 + 7;public int numDistinct(String s, String t) {char[] cs  = s.toCharArray(), ct = t.toCharArray();int m = s.length(), n = t.length();int[][] dp = new int[m + 1][n + 1];for (int i = 0; i <= m; ++i) {dp[i][0] = 1;}for (int i = 1; i <= m; ++i) {for (int j = 1; j <= n; ++j) {if (cs[i - 1] == ct[j - 1]) dp[i][j] = (dp[i - 1][j - 1] + dp[i - 1][j]) % MOD;else dp[i][j] = dp[i - 1][j] % MOD;}}return dp[m][n] % MOD;}
}

这篇关于代码随想录算法训练营Day55|LC392 判断子序列LC115 不同的子序列LC583 两个字符串的删除操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/907761

相关文章

Python实现特殊字符判断并去掉非字母和数字的特殊字符

《Python实现特殊字符判断并去掉非字母和数字的特殊字符》在Python中,可以通过多种方法来判断字符串中是否包含非字母、数字的特殊字符,并将这些特殊字符去掉,本文为大家整理了一些常用的,希望对大家... 目录1. 使用正则表达式判断字符串中是否包含特殊字符去掉字符串中的特殊字符2. 使用 str.isa

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各