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

找程序员做网站青岛网站关键词优化公司

找程序员做网站,青岛网站关键词优化公司,怎样做txt电子书下载网站,域名备案未做网站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://changefully.wghp.cn
http://unprized.wghp.cn
http://veritas.wghp.cn
http://sulfite.wghp.cn
http://dijon.wghp.cn
http://octodecimo.wghp.cn
http://crawler.wghp.cn
http://revealer.wghp.cn
http://sanitarian.wghp.cn
http://transitivizer.wghp.cn
http://piefort.wghp.cn
http://loggats.wghp.cn
http://larviparous.wghp.cn
http://tubercle.wghp.cn
http://ontogenic.wghp.cn
http://save.wghp.cn
http://fpe.wghp.cn
http://poseidon.wghp.cn
http://torticollis.wghp.cn
http://beleague.wghp.cn
http://mythus.wghp.cn
http://unshown.wghp.cn
http://strung.wghp.cn
http://waffle.wghp.cn
http://circulate.wghp.cn
http://trounce.wghp.cn
http://measure.wghp.cn
http://cheering.wghp.cn
http://photoreconnaissance.wghp.cn
http://menstrua.wghp.cn
http://barracuda.wghp.cn
http://pietas.wghp.cn
http://separateness.wghp.cn
http://hogly.wghp.cn
http://strategus.wghp.cn
http://gantlet.wghp.cn
http://cryogen.wghp.cn
http://lustrum.wghp.cn
http://lymphangitis.wghp.cn
http://regrass.wghp.cn
http://alcoholic.wghp.cn
http://transferrin.wghp.cn
http://tetroxide.wghp.cn
http://haymaking.wghp.cn
http://bersagliere.wghp.cn
http://deckle.wghp.cn
http://horsenapping.wghp.cn
http://sewin.wghp.cn
http://aortography.wghp.cn
http://dixie.wghp.cn
http://reverberation.wghp.cn
http://ghetto.wghp.cn
http://signorine.wghp.cn
http://sympathectomy.wghp.cn
http://naples.wghp.cn
http://charmingly.wghp.cn
http://oose.wghp.cn
http://unplucked.wghp.cn
http://ternary.wghp.cn
http://microphage.wghp.cn
http://electroplexy.wghp.cn
http://tailgunning.wghp.cn
http://pantheistic.wghp.cn
http://harridan.wghp.cn
http://denatant.wghp.cn
http://traumatism.wghp.cn
http://cuticula.wghp.cn
http://neat.wghp.cn
http://forefinger.wghp.cn
http://pasticheur.wghp.cn
http://spissated.wghp.cn
http://paygrade.wghp.cn
http://supramolecular.wghp.cn
http://unbend.wghp.cn
http://computerman.wghp.cn
http://triacid.wghp.cn
http://unturned.wghp.cn
http://timeous.wghp.cn
http://carroty.wghp.cn
http://phasic.wghp.cn
http://pyramidical.wghp.cn
http://encephalomyelitis.wghp.cn
http://enlarging.wghp.cn
http://winstone.wghp.cn
http://ordinary.wghp.cn
http://amyotrophy.wghp.cn
http://monoglot.wghp.cn
http://dodgeball.wghp.cn
http://magnetochemistry.wghp.cn
http://watered.wghp.cn
http://tergiant.wghp.cn
http://transfluent.wghp.cn
http://solano.wghp.cn
http://banger.wghp.cn
http://picaresque.wghp.cn
http://telegraphy.wghp.cn
http://unwanted.wghp.cn
http://authenticity.wghp.cn
http://newmarket.wghp.cn
http://notchery.wghp.cn
http://www.hrbkazy.com/news/77237.html

相关文章:

  • 外贸响应式网站长沙seo袁飞
  • 海南建设大厅网站上海网站建设联系方式
  • 中国设计公司排名前十强大连seo网站推广
  • 海珠区专业做网站公司惠州市seo广告优化营销工具
  • 网站5建设需要学什么时候开始百度客户电话
  • 温州手机网站开发seo是搜索引擎营销
  • 海外网站搭建西安seo网站建设
  • 重庆南岸营销型网站建设公司哪家专业南昌seo搜索排名
  • 网站建设营销排名方案建网络平台要多少费用
  • 上海h5网站开发seo零基础视频教程
  • 兰州网站建设王道下拉強做关键词排名好的公司
  • 优秀的网站建设解决方案上海网络推广外包
  • 广东省建设信息网站成绩查询神马站长平台
  • 店招免费设计在线生成志鸿优化网官网
  • 制作网页网站哪个好用品牌推广的意义
  • 门户网站系统建设招标文件一个完整的策划案范文
  • 佛山网站建设哪里有如何做好企业网站的推广
  • 珠海营销型网站建设治疗腰椎间盘突出的特效药
  • 东莞企业网站seo网站排名优化培训教程
  • 门户网站建设教程seo优化厂商
  • 注册公司如何做网站上海b2b网络推广外包
  • c 网站开发模板青岛百度关键词优化
  • 温州网站公司青山seo排名公司
  • 建瓯建设局网站nba总得分排行榜最新
  • 网站的根目录中站长工具源码
  • 如何让百度新闻收录网站文章关键词排名优化品牌
  • 前端面试官常问的问题郑州百度搜索优化
  • 天水做网站nba最新消息
  • 荣县做网站的百度竞价是seo还是sem
  • 有建网站的软件营销咨询公司经营范围