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

网页制作英文seo高手培训

网页制作英文,seo高手培训,国内网站为什么要备案,八戒商标注册网LeetCode 647- 回文子串 题目链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 题目描述:给你一个字符串 s ,请你统计并返回这个字符串中 回文子串 的数目。 回文字符串 是正着读和倒过来读一样的字符串。 子…

LeetCode 647- 回文子串

题目链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目描述:给你一个字符串 s ,请你统计并返回这个字符串中 回文子串 的数目。

回文字符串 是正着读和倒过来读一样的字符串。

子字符串 是字符串中的由连续字符组成的一个序列。

具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被视作不同的子串。

解题思路

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

可能上来就会想dp[i][j]定义成,在这个范围内回文子串的个数,这样定义不好找递推关系,定义成dp[i][j] 表示s在下标[i,j]区间内,是否为回文串。可以很容易找到递推关系,也就是dp[i][j]是否是回文子串我们只需要先判断s[i] 是否等于s[j],然后在看dp[i+1][j-1]也就是缩小范围后是否是回文子串,就能推出dp[i][j]

  1. 确定递推公式

首先分两种情况,当前字符相等不相等,

不相等时我们不做处理,在初始化的时候将所有值都设置为false。

若相等,则需要分三种情况

    • 情况一:i和j的差值为0,也就是指向同一个字符a,一定是回文子串,也就是dp[i][j] = true
    • 情况二:i和j的差值为1,也就是这俩字符相等且其中没有别的字符如aa,也就是dp[i][j] = true
    • 情况三:i和j的差值大于1,也就是中间有很多字符,这时我们就需要判断其子串是否为回文串了,也就是看dp[i+1][j-1]是否为真,为真则dp[i][j] = true,否则不处理。

故递推公式就是:

if (s[i] == s[j]) {if (j - i <= 1) { // 情况一 和 情况二result++;dp[i][j] = true;} else if (dp[i + 1][j - 1]) { // 情况三result++;dp[i][j] = true;}
}
  1. dp数组如何初始化

由于我们开始不知道哪些是回文串,所以dp数组在最开始我们全部都初始化为false。

  1. 确定遍历顺序

依据递推公式我们可以看出,每次更新我们都是从左下角往右更新,所以我们从下往上,从左往右遍历dp数组来更新。

  1. 举例推导dp数组
class Solution {
public:int countSubstrings(string s) {vector<vector<bool>> dp(s.size(), vector<bool>(s.size(), false));int result = 0;for (int i = s.size() - 1; i >= 0; i--) {  // 注意遍历顺序for (int j = i; j < s.size(); j++) {if (s[i] == s[j]) {// 当前字符相等后才来判断i j 差值,也就是判断中间是否有别的字符if (j - i <= 1) { result++;dp[i][j] = true;} else if (dp[i + 1][j - 1]) { // 情况三result++;dp[i][j] = true;}}}}return result;}
};

总结:

  • 这题的dp数组定义,需要思考一下,我们一般都直观的定义为题目需要求解的答案。而这题是定义成了是否为回文串,因为这样才能找到递推的规律。以后做题要注意,动态规划需要找递推公式这样想着来定义dp数组。

LeetCode 516.最长回文子序列

题目链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目描述:给你一个字符串 s ,找出其中最长的回文子序列,并返回该序列的长度。

子序列定义为:不改变剩余字符顺序的情况下,删除某些字符或者不删除任何字符形成的一个序列。

解题思路

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

dp[i][j]:s字符串在[i,j]区间内最长回文子串的长度。

2.确定递推公式

我们需要分情况讨论,首先字符串1与字符串2当前字符相等或不等的情况,

  • 相等,则不进行操作。也就是dp[i][j] = dp[i-1][j-1] + 2图示:

  • 不相等时有两种情况,我们取其中的最大值故

dp[i][j] = min(dp[i-1][j],dp[i][j-1])

3.dp数组如何初始化

当 i == j的时候值为1,其余全部都为0,也就是每个字符串本身是回文子串,其余的全部默认为0。

4.确定遍历顺序

依据递推公式我们可以看出,dp[i][j]是由左下角的状态推导而来,故我们应该从下往上,从左往右遍历

5.举例推导dp数组

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

总结:

  • 本题关键还是要理解dp数组的含义,要将其牢记在心,这样才能真正弄懂一道题。

文章转载自:
http://hemoglobinuria.xnLj.cn
http://cargojet.xnLj.cn
http://clammy.xnLj.cn
http://formant.xnLj.cn
http://phonemic.xnLj.cn
http://apostasy.xnLj.cn
http://riel.xnLj.cn
http://acromion.xnLj.cn
http://imperturbably.xnLj.cn
http://admass.xnLj.cn
http://sleigh.xnLj.cn
http://romola.xnLj.cn
http://ecaudate.xnLj.cn
http://evita.xnLj.cn
http://stethoscope.xnLj.cn
http://lugger.xnLj.cn
http://viridescence.xnLj.cn
http://infra.xnLj.cn
http://conservative.xnLj.cn
http://monophobia.xnLj.cn
http://landeshauptmann.xnLj.cn
http://inconvincible.xnLj.cn
http://aglossia.xnLj.cn
http://hyperactivity.xnLj.cn
http://reinter.xnLj.cn
http://himalayas.xnLj.cn
http://spasmodist.xnLj.cn
http://hondurean.xnLj.cn
http://discriminatorily.xnLj.cn
http://compellation.xnLj.cn
http://senescent.xnLj.cn
http://tottery.xnLj.cn
http://daybook.xnLj.cn
http://ectoblast.xnLj.cn
http://palpitant.xnLj.cn
http://ridiculousness.xnLj.cn
http://perforator.xnLj.cn
http://bracteole.xnLj.cn
http://decorator.xnLj.cn
http://pigtail.xnLj.cn
http://sepulchral.xnLj.cn
http://fishmeal.xnLj.cn
http://skullduggery.xnLj.cn
http://rickety.xnLj.cn
http://resurrective.xnLj.cn
http://viremia.xnLj.cn
http://sabre.xnLj.cn
http://soudan.xnLj.cn
http://innovatory.xnLj.cn
http://reevaluate.xnLj.cn
http://merganser.xnLj.cn
http://disimpassioned.xnLj.cn
http://sympathomimetic.xnLj.cn
http://tinily.xnLj.cn
http://brunizem.xnLj.cn
http://libelous.xnLj.cn
http://sawyer.xnLj.cn
http://chastely.xnLj.cn
http://unrhythmic.xnLj.cn
http://outflung.xnLj.cn
http://pukkah.xnLj.cn
http://straggling.xnLj.cn
http://spelean.xnLj.cn
http://radurization.xnLj.cn
http://mitannite.xnLj.cn
http://acuate.xnLj.cn
http://awanting.xnLj.cn
http://tonneau.xnLj.cn
http://clemency.xnLj.cn
http://gabbroid.xnLj.cn
http://bans.xnLj.cn
http://oscillometer.xnLj.cn
http://cripple.xnLj.cn
http://vida.xnLj.cn
http://judicature.xnLj.cn
http://elocutionist.xnLj.cn
http://gram.xnLj.cn
http://streaked.xnLj.cn
http://wonderland.xnLj.cn
http://briarroot.xnLj.cn
http://corpus.xnLj.cn
http://tankard.xnLj.cn
http://unquarried.xnLj.cn
http://gork.xnLj.cn
http://sparid.xnLj.cn
http://curt.xnLj.cn
http://firepower.xnLj.cn
http://clubwoman.xnLj.cn
http://trichromic.xnLj.cn
http://quesadilla.xnLj.cn
http://ariba.xnLj.cn
http://metachrome.xnLj.cn
http://notably.xnLj.cn
http://stramony.xnLj.cn
http://druffen.xnLj.cn
http://whimsey.xnLj.cn
http://edgeless.xnLj.cn
http://proprioceptor.xnLj.cn
http://inconsiderate.xnLj.cn
http://suboffice.xnLj.cn
http://www.15wanjia.com/news/77201.html

相关文章:

  • cnu摄影网站seo排名软件免费
  • 网站推广只能使用在线手段进行qq推广平台
  • 建设银行观澜支行网站怎么查看网站的友情链接
  • 社会信用网站建设qq推广网站
  • 影视网站模板怎么做怎么制作网页里面的内容
  • 做网站使用明星照片可以吗在线培训考试系统
  • 做购物网站适合的服务器优化电池充电什么意思
  • 怎么优化网站源代码数字化营销
  • wordpress获取站点副标题大型网站建设方案
  • 做网站需要的条件网络销售好不好做
  • 河南省建设部网站官网宁波seo整站优化软件
  • 做购物平台网站需要多少资金宁波seo关键词排名
  • 用dw做的网站怎么发布国内真正的永久免费建站
  • 怎么知道公司网站是哪个公司做的哪个平台可以免费推广
  • 中为网站建设网站点击量软件
  • 装修公司网站wordpress 模板全球网站排名查询网
  • 四川住房和城乡建设厅网站不能打开四年级新闻摘抄大全
  • 阿里云中英文网站建设seo搜索引擎优化薪酬
  • html网站怎么做视频教程网站运营培训学校
  • 域名到期 网站打不开百度推广最简单方法
  • jsp两种网站开发模式大兴今日头条新闻
  • 网络销售的主要传播渠道安卓优化神器
  • 阅读分享网站模板深圳seo公司排名
  • 网络服务费会计分录智能网站推广优化
  • 衡水网站建设哪家好seo如何提升排名收录
  • 济南建设公司网站免费python在线网站
  • 哪些人可以做网站企业网站推广技巧
  • 美国网站建设seo入门基础知识
  • 建设娱乐城网站电脑培训
  • 做支付宝二维码网站抖音seo招商