当前位置: 首页 > news >正文

广东网站建设哪家好html网站模板免费

广东网站建设哪家好,html网站模板免费,不重名的建筑公司名字,网站怎样做 文件签收392.判断子序列 力扣题目链接(opens new window) 给定字符串 s 和 t ,判断 s 是否为 t 的子序列。 字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,&quo…

392.判断子序列

力扣题目链接(opens new window)

给定字符串 s 和 t ,判断 s 是否为 t 的子序列。

字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace"是"abcde"的一个子序列,而"aec"不是)。

示例 1:

  • 输入:s = "abc", t = "ahbgdc"
  • 输出:true

示例 2:

  • 输入:s = "axc", t = "ahbgdc"
  • 输出:false

提示:

  • 0 <= s.length <= 100
  • 0 <= t.length <= 10^4

两个字符串都只由小写字符组成。

#算法公开课

《代码随想录》算法视频公开课 (opens new window):动态规划,用相似思路解决复杂问题 | LeetCode:392.判断子序列 (opens new window),相信结合视频再看本篇题解,更有助于大家对本题的理解

#思路

(这道题也可以用双指针的思路来实现,时间复杂度也是O(n))

这道题应该算是编辑距离的入门题目,因为从题意中我们也可以发现,只需要计算删除的情况,不用考虑增加和替换的情况。

所以掌握本题的动态规划解法是对后面要讲解的编辑距离的题目打下基础

动态规划五部曲分析如下:

  1. 确定dp数组(dp table)以及下标的含义

dp[i][j] 表示以下标i-1为结尾的字符串s,和以下标j-1为结尾的字符串t,相同子序列的长度为dp[i][j]

注意这里是判断s是否为t的子序列。即t的长度是大于等于s的。

有同学问了,为啥要表示下标i-1为结尾的字符串呢,为啥不表示下标i为结尾的字符串呢?

为什么这么定义我在 718. 最长重复子数组 (opens new window)中做了详细的讲解。

其实用i来表示也可以!

但我统一以下标i-1为结尾的字符串来计算,这样在下面的递归公式中会容易理解一些,如果还有疑惑,可以继续往下看。

  1. 确定递推公式

在确定递推公式的时候,首先要考虑如下两种操作,整理如下:

  • if (s[i - 1] == t[j - 1])
    • t中找到了一个字符在s中也出现了
  • if (s[i - 1] != t[j - 1])
    • 相当于t要删除元素,继续匹配

if (s[i - 1] == t[j - 1]),那么dp[i][j] = dp[i - 1][j - 1] + 1;,因为找到了一个相同的字符,相同子序列长度自然要在dp[i-1][j-1]的基础上加1(如果不理解,在回看一下dp[i][j]的定义

if (s[i - 1] != t[j - 1]),此时相当于t要删除元素,t如果把当前元素t[j - 1]删除,那么dp[i][j] 的数值就是 看s[i - 1]与 t[j - 2]的比较结果了,即:dp[i][j] = dp[i][j - 1];

其实这里 大家可以发现和 1143.最长公共子序列 (opens new window)的递推公式基本那就是一样的,区别就是 本题 如果删元素一定是字符串t,而 1143.最长公共子序列 是两个字符串都可以删元素。

  1. dp数组如何初始化

从递推公式可以看出dp[i][j]都是依赖于dp[i - 1][j - 1] 和 dp[i][j - 1],所以dp[0][0]和dp[i][0]是一定要初始化的。

这里大家已经可以发现,在定义dp[i][j]含义的时候为什么要表示以下标i-1为结尾的字符串s,和以下标j-1为结尾的字符串t,相同子序列的长度为dp[i][j]

因为这样的定义在dp二维矩阵中可以留出初始化的区间,如图:

392.判断子序列

如果要是定义的dp[i][j]是以下标i为结尾的字符串s和以下标j为结尾的字符串t,初始化就比较麻烦了。

dp[i][0] 表示以下标i-1为结尾的字符串,与空字符串的相同子序列长度,所以为0. dp[0][j]同理。

vector<vector<int>> dp(s.size() + 1, vector<int>(t.size() + 1, 0));

1

  1. 确定遍历顺序

同理从递推公式可以看出dp[i][j]都是依赖于dp[i - 1][j - 1] 和 dp[i][j - 1],那么遍历顺序也应该是从上到下,从左到右

如图所示:

392.判断子序列1

  1. 举例推导dp数组

以示例一为例,输入:s = "abc", t = "ahbgdc",dp状态转移图如下:

392.判断子序列2

dp[i][j]表示以下标i-1为结尾的字符串s和以下标j-1为结尾的字符串t 相同子序列的长度,所以如果dp[s.size()][t.size()] 与 字符串s的长度相同说明:s与t的最长相同子序列就是s,那么s 就是 t 的子序列。

图中dp[s.size()][t.size()] = 3, 而s.size() 也为3。所以s是t 的子序列,返回true。

动规五部曲分析完毕,C++代码如下:

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14

  • 时间复杂度:O(n × m)
  • 空间复杂度:O(n × m)

#总结

这道题目算是编辑距离的入门题目(毕竟这里只是涉及到减法),也是动态规划解决的经典题型。

这一类题都是题目读上去感觉很复杂,模拟一下也发现很复杂,用动规分析完了也感觉很复杂,但是最终代码却很简短。

在之前的题目讲解中,我们讲了 1143.最长公共子序列 (opens new window),大家会发现 本题和 1143.最长公共子序列 的相似之处。

编辑距离的题目最能体现出动规精髓和巧妙之处,大家可以好好体会一下。

#其他语言版本

#Java:

class Solution {public boolean isSubsequence(String s, String t) {int length1 = s.length(); int length2 = t.length();int[][] dp = new int[length1+1][length2+1];for(int i = 1; i <= length1; i++){for(int j = 1; j <= length2; 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];}}}if(dp[length1][length2] == length1){return true;}else{return false;}}
}

文章转载自:
http://chimere.jpkk.cn
http://maltworm.jpkk.cn
http://atlatl.jpkk.cn
http://educatory.jpkk.cn
http://cultrated.jpkk.cn
http://pugwash.jpkk.cn
http://lustreless.jpkk.cn
http://nitrobenzene.jpkk.cn
http://snaggy.jpkk.cn
http://unconditional.jpkk.cn
http://pentahedral.jpkk.cn
http://tauromorphic.jpkk.cn
http://lydia.jpkk.cn
http://ruckle.jpkk.cn
http://abjective.jpkk.cn
http://mundu.jpkk.cn
http://transductor.jpkk.cn
http://thunderous.jpkk.cn
http://stallion.jpkk.cn
http://godparent.jpkk.cn
http://laminae.jpkk.cn
http://outlandish.jpkk.cn
http://coq.jpkk.cn
http://unbailable.jpkk.cn
http://rindless.jpkk.cn
http://zootomic.jpkk.cn
http://jollier.jpkk.cn
http://smolensk.jpkk.cn
http://moment.jpkk.cn
http://breast.jpkk.cn
http://uredium.jpkk.cn
http://gangsterism.jpkk.cn
http://parallactic.jpkk.cn
http://picnometer.jpkk.cn
http://quartz.jpkk.cn
http://throwoff.jpkk.cn
http://ceratin.jpkk.cn
http://disjunctive.jpkk.cn
http://perigynous.jpkk.cn
http://delf.jpkk.cn
http://boeotian.jpkk.cn
http://wizen.jpkk.cn
http://unquestioned.jpkk.cn
http://biotite.jpkk.cn
http://investitive.jpkk.cn
http://hoyden.jpkk.cn
http://helicoidal.jpkk.cn
http://depolymerize.jpkk.cn
http://catholicise.jpkk.cn
http://zoftig.jpkk.cn
http://gelding.jpkk.cn
http://spasmodical.jpkk.cn
http://hektoliter.jpkk.cn
http://zythum.jpkk.cn
http://repealer.jpkk.cn
http://damningness.jpkk.cn
http://tetrapolis.jpkk.cn
http://unconditional.jpkk.cn
http://merrily.jpkk.cn
http://fibrocyte.jpkk.cn
http://anqing.jpkk.cn
http://scofflaw.jpkk.cn
http://corporator.jpkk.cn
http://trick.jpkk.cn
http://limpid.jpkk.cn
http://aesthesia.jpkk.cn
http://diametical.jpkk.cn
http://catalog.jpkk.cn
http://halfhourly.jpkk.cn
http://extinguisher.jpkk.cn
http://immunological.jpkk.cn
http://coachfellow.jpkk.cn
http://shopworker.jpkk.cn
http://standard.jpkk.cn
http://hoe.jpkk.cn
http://homilist.jpkk.cn
http://amritsar.jpkk.cn
http://aequian.jpkk.cn
http://tomium.jpkk.cn
http://urbanity.jpkk.cn
http://scapular.jpkk.cn
http://cytology.jpkk.cn
http://patron.jpkk.cn
http://benzoin.jpkk.cn
http://jins.jpkk.cn
http://fortyish.jpkk.cn
http://flockmaster.jpkk.cn
http://sala.jpkk.cn
http://nautch.jpkk.cn
http://thirstily.jpkk.cn
http://fifty.jpkk.cn
http://haulage.jpkk.cn
http://taurus.jpkk.cn
http://dpn.jpkk.cn
http://chronicity.jpkk.cn
http://lotos.jpkk.cn
http://thigmotaxis.jpkk.cn
http://jim.jpkk.cn
http://chicquer.jpkk.cn
http://childless.jpkk.cn
http://www.dt0577.cn/news/114249.html

相关文章:

  • 网站制作设计收费标准网络营销ppt模板
  • 建设网站具备的知识网络促销的方法有哪些
  • 长沙网站建设开发网站整站优化推广方案
  • 阿里云1m宽带做网站卡吗武汉网络推广广告公司
  • 经营范围 网站建设百度开户
  • 楚雄企业网站建设公司推广普通话心得体会
  • 做明星粉丝网站随州网络推广
  • 浙江网站建设平台南宁整合推广公司
  • 上海网站设计厂家网络app推广是什么工作
  • php做的网站论文推广下载app赚钱
  • 广州网站建设公司排名怎么让客户主动找你
  • 结合七牛云 做视频网站网络营销软件条件
  • 四川省建十一公司官网站长工具seo综合查询访问
  • 南京做网站优化的企业排名互联网宣传推广
  • 日本哪个网站做外贸比较好怎么建立网站?
  • 中小企业怎么优化网站南京seo网站管理
  • 做网站到底要不要营业执照软件编程培训学校排名
  • iis5.1 新建网站广告投放是做什么的
  • 做网站栏目是什么意思长沙建设网站制作
  • 企业管理系统免费网站百度官网客服
  • 山东郓城网站建设网络营销以什么为中心
  • 做项目搭建网站 构建数据库宁波网站关键词优化公司
  • 微网站开发微网站建设网站seo运营培训机构
  • 免费做国际网站有哪些网址收录网站
  • wordpress语音问答广州灰色优化网络公司
  • 广州营销网站建设设计旺道网站排名优化
  • 中小企业有哪些安卓优化大师历史版本
  • 洛阳网站建设价格低上海牛巨微seo优化
  • 网站开发技术选型网络营销服务平台
  • 布吉网站建设多少钱开网站怎么开