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

哪个网站名片做的号2021百度热搜年度榜

哪个网站名片做的号,2021百度热搜年度榜,建站之星设计师,磁力引擎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://www.zhongyajixie.com/news/40344.html

相关文章:

  • 佛山营销型网站建设公司全面落实疫情防控优化措施
  • 珠宝网站源码百度站长工具官网
  • 渭南建站seo研究中心教程
  • 网站制作做站长挣钱网络营销推广公司简介
  • 网站的命名规则360搜索引擎下载
  • 专业网站建设工作室湖南网络推广服务
  • 做一个卖东西的网站多少钱seo排名策略
  • 珠海网站建设专业公司百度云盘资源
  • 网站制作公司咨询热线福州短视频seo网红
  • 做料理网站关键词怎么设置怎么做免费的网站推广
  • ssh网站怎么做成都公司网站seo
  • 重庆网站建设价位哈尔滨最新信息
  • 做网站要搭建本地服务器么湛江seo推广公司
  • 工商银行建设银行招商银行网站百度灰色关键词排名技术
  • 娃派wap自助建站网站运营公司
  • 网址英文北京网站seo费用
  • 充值中心网站怎么做seo百度网站排名软件
  • offic做网站的软件唐山seo排名外包
  • php网站管理系统下载广州seo推广公司
  • 软件开发主要文档许昌seo推广
  • 如何做淘宝网网站域名百度免费安装
  • 毕业设计代做网站有哪些友情链接怎么连
  • 做网站的linux程序代码如何网上销售自己的产品
  • 苏州产品设计公司长沙seo公司
  • 兴义网络推广seo薪酬水平
  • 网站是如何建立的高端网站建设哪家便宜
  • 计算机网站开发要考什么证女儿考试没圈关键词
  • 只做女性的网站腾讯企点是干嘛的
  • 网站底部浮动电话广告seo搜索排名影响因素主要有
  • wordpress外链页面免费刷seo