Problem: 5. 最长回文子串
题目描述
思路
思路1:双指针
1.我们利用双指针从中间向两边扩散来判断是否为回文串,则关键是找到以s[i]为中心的回文串;
2.我们编写一个函数string palindrome(string &s, int left, int right)用于返回以索引为i作为中心向两边的的回文子串
3.由于可能出现奇数或者偶数长度的回文串,所以我们需要在遍历时,求出**palindrome(s, i, i)与palindrome(s, i, i + 1)**的回文串,并取出其中的较大值
思路2:动态规划
1.状态定义:dp[i][j]表示s[i…j]是回文字符串(定义为bool类型若为true则表示是回文串);
2.状态初始化:所有长度为0的均为回文串,即dp[i][i] == true;
3.状态转移:若s[i] != s[j],则dp[i][j] == false,若s[i] = s[j],则dp[i][j] = dp[i + 1][j - 1]
复杂度
思路1:
时间复杂度:
O ( N 2 ) O(N^2) O(N2);其中 N N N为字符串的长度
空间复杂度:
O ( N ) O(N) O(N)
思路2:
时间复杂度:
O ( N 2 ) O(N^2) O(N