647. 回文子串
给你一个字符串 s ,请你统计并返回这个字符串中 回文子串 的数目。
回文字符串 是正着读和倒过来读一样的字符串。
子字符串 是字符串中的由连续字符组成的一个序列。
示例 1:
输入:s = "abc" 输出:3 解释:三个回文子串: "a", "b", "c"
示例 2:
输入:s = "aaa" 输出:6 解释:6个回文子串: "a", "a", "a", "aa", "aa", "aaa"
class Solution:
def countSubstrings(self, s: str) -> int:
dp=[[False for i in range(len(s))] for i in range(len(s))]
result=0
for i in range(len(s)-1,-1,-1):
for j in range(i,len(s)):
if s[i]==s[j]:
if j-i<=1:
dp[i][j]=True
result+=1
elif dp[i+1][j-1]:
dp[i][j]=dp[i+1][j-1]
result+=1
return result
516. 最长回文子序列
给你一个字符串 s ,找出其中最长的回文子序列,并返回该序列的长度。
子序列定义为:不改变剩余字符顺序的情况下,删除某些字符或者不删除任何字符形成的一个序列。
示例 1:
输入:s = "bbbab" 输出:4 解释:一个可能的最长回文子序列为 "bbbb" 。
示例 2:
输入:s = "cbbd" 输出:2 解释:一个可能的最长回文子序列为 "bb" 。
class Solution:
def longestPalindromeSubseq(self, s: str) -> int:
dp=[[0 for i in range(len(s))] for i in range(len(s))]
for i in range(len(s)-1,-1,-1):
for j in range(i,len(s)):
if s[i]==s[j]:
if i==j:
dp[i][j]=1
elif j-i==1:
dp[i][j]=2
else:
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][-1]
回文子串与子序列问题解析
436

被折叠的 条评论
为什么被折叠?



