蓝色表示遍历顺序
// dp[i][j] s[i, j]范围内回文子串个数
// if (s[i]==s[j]){
// if (j-i<=1){
// dp[i][j]=true;
// result++;
// }
// else if(dp[i+1][j-1]){
// dp[i][j]=true;
// result++;
// }
// }
// 初始化false;
class Solution {
public:
int countSubstrings(string s) {
int result=0;
vector<vector<bool>> dp(s.size(), vector<bool>(s.size(), false));
for (int i=s.size()-1; i>=0; i--){
for (int j=i; j<s.size(); j++){
if (s[i]==s[j]){
if (j-i<=1){
dp[i][j]=true;
result++;
}
else if(dp[i+1][j-1]){
dp[i][j]=true;
result++;
}
}
}
}
return result;
}
};
#516.最长回文子序列
// dp[i][j]:字符串s在[i, j]范围内最长的回文子序列的长度为dp[i][j]。
// dp[i][j]=dp[i+1][j-1]+2;
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];
}
};