代码随想录算法训练营第五十四天|LeetCode392 判断子序列、LeetCode115 不同的子序列

本文主要是介绍代码随想录算法训练营第五十四天|LeetCode392 判断子序列、LeetCode115 不同的子序列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

392.判断子序列

思路:本质还是寻找s与t的最长公共子序列,如果最长公共子序列长度与s的长度相同,说明s为t的子序列。因此确定dp数组及其下标含义dp[i][j]为以s[i-1]和t[j-1]的子序列的最长公共子序列长度,递推公式,如果s[i-1]==t[j-1],dp[i][j] = dp[i-1][j-1]+1.如果不相等,dp[i][j] = dp[i][j-1],因为s整段都需要判断,因此不能考虑s删元素的情况,只考虑t删元素的情况。初始化dp数组,都为零,第-1个元素没意义。遍历顺序,从小到大。

class Solution {
public:bool isSubsequence(string s, string t) {//判断两个公共子序列的最大长度是不是 短序列的长度//dp[i][j]表示以s[i-1]和t[j-1]为结尾的两个序列的最长公共序列长度 这样定义方便初始化//if(s[i-1]==t[j-1]) dp[i][j] = dp[i-1][j-1]+1; else dp[i][j] = max(dp[i-1][j],dp[i][j-1])int size1 = s.size();int size2 = t.size();vector<vector<int>> dp(size1+1,vector<int>(size2+1,0));int maxnum = 0;for(int i = 1;i<=size1;i++){for(int j =1;j<=size2;j++){if(s[i-1]==t[j-1]){dp[i][j] = dp[i-1][j-1]+1;maxnum = maxnum>dp[i][j]?maxnum:dp[i][j];}else{dp[i][j] = dp[i][j-1];}}}if(maxnum == size1){return true;}else{return false;}}
};

115.不同的子序列

思路:仍然是判断s和t的序列关系,跟上道题的递推公式有些相似,首先定义dp数组及其下标含义dp[i][j]表示以s[i-1]结尾的序列包含以t[j-1]结尾的序列的最大个数。递推公式:如果s[i-1]==t[j-1]有两种情况,第一种考虑s[i-1],最大个数为dp[i-1][j-1],第二种不考虑s[i-1],最大个数为dp[i-1][j]。因此dp[i][j] = dp[i-1][j-1]+dp[i-1][j].如果s[i-1]!=t[j-1],直接不考虑s[i-1].dp[i][j] = dp[i-1][j].初始化dp数组,dp[i][0],s字符串(无论是否为空)一定包含空字符串t,dp[0][j]=0,字符串s为空,t非空时,一定不包含t。遍历顺序,从小到大。

class Solution {
public:int numDistinct(string s, string t) {//确定dp数组及其下标含义 dp[i][j] 表示以s[i-1]结尾的字符串包含 以t[j-1]结尾的字符串的个数//递推公式 如果s[i-1]==t[j-1],dp[i][j]由两种情况组成//1、使用s[i-1],dp[i][j] = dp[i-1][j-1]; 个数为以s[i-2]和t[i-2]结尾的字符串包含个数//2、不使用s[i-1],dp[i][j] = dp[i-1][j]; 个数为以s[i-2]和t[i-1]结尾的字符串包含个数//dp[i][j] = dp[i-1][j-1]+dp[i-1][j];//初始化dp数组//dp[i][0]=1 和dp[0][j] = 0,因为s一定包含空字符串,而空字符串不会包含非空字符串。int size1 = s.size();int size2 = t.size();vector<vector<uint64_t>> dp(size1+1,vector<uint64_t>(size2+1,0));for(int i = 0;i<size1;i++){dp[i][0]=1;}for(int i =1;i<=size1;i++){for(int j =1;j<=size2;j++){if(s[i-1]==t[j-1]){dp[i][j] = dp[i-1][j-1]+dp[i-1][j];}else{dp[i][j] = dp[i-1][j];}}}return dp[size1][size2];}
};

int类型数据会溢出,使用uint64_t.

这篇关于代码随想录算法训练营第五十四天|LeetCode392 判断子序列、LeetCode115 不同的子序列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Python如何精准判断某个进程是否在运行

《Python如何精准判断某个进程是否在运行》这篇文章主要为大家详细介绍了Python如何精准判断某个进程是否在运行,本文为大家整理了3种方法并进行了对比,有需要的小伙伴可以跟随小编一起学习一下... 目录一、为什么需要判断进程是否存在二、方法1:用psutil库(推荐)三、方法2:用os.system调用

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

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

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

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

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

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

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

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

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

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

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

openCV中KNN算法的实现

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