leetcode392--判断子序列

2024-04-30 16:04
文章标签 判断 序列 leetcode392

本文主要是介绍leetcode392--判断子序列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 题意

判断字符串 s s s是否为 t t t的子序列

2. 题解

2.1 双指针

对于在 t t t中找到的 s [ i ] s[i] s[i]字符,我们只需要找下一个即可。

即一个指针 i i i指向 s s s,一个指针 j j j指向 t t t;

  • s [ i ] = = t [ j ] , i ← i + 1 , j ← j + 1 s[i] ==t[j], i \leftarrow i+1,j \leftarrow j+1 s[i]==t[j],ii+1,jj+1
  • s [ i ] ≠ t [ j ] , i ← i + 1 s[i] \ne t[j], i \leftarrow i+1 s[i]=t[j],ii+1

代码

class Solution {
public:bool isSubsequence(string s, string t) {int slen = s.size();int tlen = t.size();if ( slen > tlen)return false;int i = 0;int j = 0;while ( i < slen && j < tlen ) {if (s[i] == t[j])++i,++j;else {++j;}}return i == slen; }
};
2.2 双指针+预处理

我们可以预处理 j j j,当 s [ i ] ≠ t [ j ] s[i]\ne t[j] s[i]=t[j], j j j跳到下一个邻近 s [ i ] s[i] s[i]表示字符出现的位置。

预处理我们可以从后往前遍历;得到转移方程

d p [ i ] [ j ] = { d p [ i + 1 ] [ j ] , c = = ′ a ′ + j i , c ≠ ′ a ′ + j dp[i][j]= \begin{cases} dp[i+1][j], \quad c == 'a'+j\\ i, \quad c \ne 'a'+j \end{cases} dp[i][j]={dp[i+1][j],c==a+ji,c=a+j

d p [ i ] [ j ] dp[i][j] dp[i][j]表示在字符串 t t t中的 i i i位置与其右端最邻近的 j + ′ a ′ j +'a' j+a字符的位置。

这个dp数组的作用,是来加速上面双指针中 j j j指针的跳转。


class Solution {
public:bool isSubsequence(string s, string t) {int n = s.size();int m = t.size();vector<vector<int>> dp(m + 1, vector<int>(26, m));for (int i = m - 1; ~i ; --i) {for (int j = 0;j < 26; ++j) {if ( j + 'a' == t[i]) {dp[i][j] = i;}else {dp[i][j] = dp[i + 1][j];}}}int i = 0;int j = 0;while (i < n && j < m) {if (s[i] == t[j]) {i++;j++;}else {j = dp[j][s[i] - 'a'];}}return i == n; }
};
2.3 动态规划

可以转换为经典的 L C S ( l o n g e s t c o m m o n s e q u e n c e ) LCS(longest\ common\ sequence) LCS(longest common sequence)最长公共子序列问题,

L C S ( s , t ) = s . s i z e ( ) LCS(s,t) =s.size() LCS(s,t)=s.size()

class Solution {
public:bool isSubsequence(string s, string t) {if (s.empty())return true;int m = static_cast<int>( s.size() );int n = static_cast<int>( t.size() );vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0));for (int i = 1;i <= m; ++i) {for ( int j = 1; j <= n; ++j) {if (s[i - 1] == t[j - 1])dp[i][j] = dp[i - 1][j - 1] + 1;elsedp[i][j] = max( dp[i][j - 1], dp[i - 1][j]);}}return dp[m][n] == m;}
};

这篇关于leetcode392--判断子序列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

Python如何判断字符串中是否包含特殊字符并替换

《Python如何判断字符串中是否包含特殊字符并替换》这篇文章主要为大家详细介绍了如何使用Python实现判断字符串中是否包含特殊字符并使用空字符串替换掉,文中的示例代码讲解详细,感兴趣的小伙伴可以了... 目录python判断字符串中是否包含特殊字符方法一:使用正则表达式方法二:手动检查特定字符Pytho

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序

判断PyTorch是GPU版还是CPU版的方法小结

《判断PyTorch是GPU版还是CPU版的方法小结》PyTorch作为当前最流行的深度学习框架之一,支持在CPU和GPU(NVIDIACUDA)上运行,所以对于深度学习开发者来说,正确识别PyTor... 目录前言为什么需要区分GPU和CPU版本?性能差异硬件要求如何检查PyTorch版本?方法1:使用命

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

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

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

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

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

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

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque