class Solution {
public:
int countSubstrings(string s) {
vector<vector<bool>> dp(s.size(), vector<bool>(s.size(), false));
int result = 0;
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) { // 情况一 和 情况二
result++;
dp[i][j] = true;
} else if (dp[i + 1][j - 1]) { // 情况三
result++;
dp[i][j] = true;
}
}
}
}
return result;
}
};
代码随想录算法训练营第五十七天 | 力扣 647. 回文子串
于 2024-03-26 00:55:37 首次发布
该代码片段展示了一个名为Solution的类,用于计算给定字符串中回文子串的数量,采用动态规划方法。遍历字符串,检查字符对是否相等,并利用之前子问题的结果更新状态。
摘要由CSDN通过智能技术生成