给你一个字符串 s ,请你统计并返回这个字符串中 回文子串 的数目。
回文字符串 是正着读和倒过来读一样的字符串。
子字符串 是字符串中的由连续字符组成的一个序列。
具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被视作不同的子串。
JAVA(dp):
class Solution {
public int countSubstrings(String s) {
int n=s.length();
boolean[][] dp=new boolean[n][n];
int res=0;
//一个元素
for(int i=0;i<n;i++){
dp[i][i]=true;
res++;
}
//前后相同元素
for(int i=0;i<n-1;i++){
if(s.charAt(i)==s.charAt(i+1)){
dp[i][i+1]=true;
res++;
}
}
for(int len=3;len<=n;len++){
for(int i=0;i+len<=n;i++){
int j=i+len-1;
if(s.charAt(i)==s.charAt(j)){
dp[i][j]=dp[i+1][j-1];
if(dp[i][j]){
res++;
}
}
}
}
return res;
}
}
JAVA(中心扩展法):
class Solution {
public int countSubstrings(String s) {
int ans=0;
for(int center=0;center<2*s.length()-1;center++){
int left=center/2;
int right=left+center%2;
while(left>=0&&right<s.length()&&s.charAt(left)==s.charAt(right)){
ans++;
left--;
right++;
}
}
return ans;
}
}