【LeetCode】最长回文子串【动态规划或中心扩展】
给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。
示例 1:
输入: "babad"
输出: "bab"
注意: "aba" 也是一个有效答案。示例 2:
输入: "cbbd"
输出: "bb"来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-palindromic-substring
方法1:动态规划
最优子结构:当一个串是一个回文串的时候,在其头尾各加一个相同的字符组成的新字符串依旧是一个回文串
dp[i][j]=1,代表从下标i到下标j组成的字符串是一个回文串
如果s[i]==s[j]&&dp[i+1][j-1]==1,那么dp[i][j]=1
初始化:
1.对于一个字符的回文串:dp[i][i]=1
2.对于两个字符的回文串:如果s[i]==s[i+1],那么dp[i][i+1]=1
对于三个字符的回文串:如果s[i]==s[j]&&dp[i+1][j-1]==1,那么dp[i][j]=1
时间复杂度:O(N^2)
空间复杂度:O(N^2)
class Solution {
public:
string longestPalindrome(string s)
{
if(s.size()==)
return "";
if(s.size()==)
return s;
if(s.size()==&&s[]==s[])
return s;
int n=s.length();
int dp[n+][n+];
memset(dp,,sizeof(dp));
int ans=;
int start=;
for(int i=;i<n;i++)
{
dp[i][i]=;
}
for(int i=;i<n-;i++)
{
if(s[i]==s[i+])
{
dp[i][i+]=;
ans=;
start=i;
}
}
int l=;
while(l<=n)
{
for(int i=;i<n-l+;i++)
{
int j=i+l-;
if(dp[i+][j-]==&&s[i]==s[j])
{
dp[i][j]=;
start=i;
ans=l;
}
}
l++;
}
return s.substr(start,ans);
}
};
方法2:中心扩展法
将每个字符当作回文串的中心,然后往两边扩展,取扩展得到的回文串的最大值就是最长回文子串
考虑到回文串的奇偶情况,我们可以算两种情况:以一个字符为回文串的中心,以两个字符为回文串的中心,然后去二者最大值就可以
时间复杂度:O(N^2),以每个字符为中心需要遍历一次,然后每次都需要往两边扩展
空间复杂度:O(1),只需要用到一些常量
class Solution {
public:
int f1(string str,int left,int right,int n)
{
int c=;
//cout<<"left="<<left<<" right="<<right<<" n="<<n<<endl;
left--;
right++; while(left>=&&right<n&&str[left]==str[right])
{
left--;
right++;
c+=;
}
return c;
}
int f2(string str,int left,int right,int n)
{ int c=;
if(str[left]==str[right])
c=;
else
{
c=;
return c;
}
left--;
right++;
while(left>=&&right<n&&str[left]==str[right])
{
left--;
right++;
c+=;
}
return c;
}
string longestPalindrome(string s)
{
int n=s.size();
if(n==)
return "";
if(n==)
return s;
if(n==&&s[]==s[])
return s;
int ans=;
int start=;
for(int i=;i<n-;i++)
{
int x1=f1(s,i,i,n);
int x2=f2(s,i,i+,n);
//cout<<"i="<<i<<" x1="<< x1<<" x2="<<x2<<endl;
if(max(x1,x2)>ans)
{
ans=max(x1,x2);
//cout<<"ans="<<ans<<endl;
if(ans%==)
start=i-ans/;
else
start=i-(ans-)/;
//cout<<"start="<<start<<endl;
}
}
return s.substr(start,ans);
}
};
还有一个解决方案是马拉车算法
时间复杂度为O(N)!!!
但是我目前也没有掌握,就没有贴出来,怕误导别人
【LeetCode】最长回文子串【动态规划或中心扩展】的更多相关文章
- [LeetCode]最长回文子串 java
题目: 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为1000. 示例 1: 输入: "babad" 输出: "bab" 注意: ...
- leetcode -- 最长回文子串
题目: 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 示例 1: 输入: "babad" 输出: "bab" 注意: ...
- leetcode-5 最长回文子串(动态规划)
题目要求: * 给定字符串,求解最长回文子串 * 字符串最长为1000 * 存在独一无二的最长回文字符串 求解思路: * 回文字符串的子串也是回文,比如P[i,j](表示以i开始以j结束的子串)是回文 ...
- LeetCode.5-最长回文子串(Longest Palindromic Substring)
这是悦乐书的第342次更新,第366篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Medium级别的第3题(顺位题号是5).给定一个字符串s,找到s中最长的回文子字符串. 您可以假设s ...
- LeetCode最长回文子串
题目: 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 示例 1: 输入: "babad"输出: "bab"注意: & ...
- 【C++】最长回文子串/动态规划
ACM #include <bits/stdc++.h> using namespace std; const int maxn = 1010; char S[maxn]; int dp[ ...
- [LeetCode] 5. 最长回文子串 ☆☆☆(最长子串、动态规划)
最长回文子串 (动态规划法.中心扩展算法) https://leetcode-cn.com/problems/longest-palindromic-substring/solution/xiang- ...
- Leetcode(5)-最长回文子串(包含动态规划以及Manacher算法)
给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为1000. 示例 1: 输入: "babad" 输出: "bab" 注意: &quo ...
- LeetCode(5):最长回文子串
Medium! 题目描述: 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 长度最长为1000. 示例: 输入: "babad" 输出: "bab&quo ...
随机推荐
- FFT/NTT [51Nod 1028] 大数乘法 V2
题目链接:51Nod 传送门 没压位,效率会低一点 1.FFT #include <cstdio> #include <cstring> #include <algori ...
- Redis 高可用架构设计(转载)
转载自:https://mp.weixin.qq.com/s?__biz=MzA3NDcyMTQyNQ==&mid=2649263292&idx=1&sn=b170390684 ...
- web 介绍
Web介绍: w3c:万维网联盟组织,用来制定web标准的机构(组织) web标准:制作网页遵循的规范 web准备规范的分类:结构标准.表现标准.行为标准. 结构:html.表示:css.行为:Jav ...
- 产品生命周期(Product Life Circle,PLC)
什么是产品生命周期? 产品生命周期是新产品从开发进入市场到被市场淘汰的整个过程.产品生命周期可分为初创期.成长期.成熟期.衰退期. 产品生命周期有什么用? 在产品不同的生命阶段,公司的业务目的都不同. ...
- Python3菜鸟教程笔记
多行语句 同一行显示多条语句 Print 输出
- IDEA中用mybatis插件生成逆向工程
目录 maven项目 在resources目录下新建generatorConfig.xml文件 在resources目录下新建config.properties文件 运行 maven项目 <?x ...
- Atcoder Regular Contest 060 F题第一问答案证明
一切的开始 令 \(x\) 为字符串,\(p\) 为正整数.如果对于满足 \(0\le i<|x|−p\) 的任何整数 \(i\) 满足 \(x[i]=x[i+p]\),则 \(p\) 称为 \ ...
- CTF 文件包含
目录 一.基本概念 二.本地文件包含 三.远程文件包含 四.具体场景 五.补充 一.基本概念 文件包含 将相同函数写入单独的文件中,需要使用时直接调用 文件包含漏洞 将被包含的文件设置为变量,导致客户 ...
- 剑指offer:整数中1出现的次数
题目描述: 求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1.10.11.12.13因此共出现6次,但是对于后面问题他就没辙了 ...
- vue elementUi tree 懒加载使用详情
背景:vue下使用elementUI 文档:http://element-cn.eleme.io/#/zh-CN/component/tree#tree-shu-xing-kong-jian 需求:只 ...