day57第九章 动态规划part17 647. 回文子串 516.最长回文子序列 动态规划总结篇

第九章 动态规划part17

    1. 回文子串
  • 516.最长回文子序列
  • 动态规划总结篇

647. 回文子串

java 复制代码
class Solution {
    public int countSubstrings(String s) {
        int n = s.length();

        // 创建动态规划表 dp[i][j] 表示从 i 到 j  的子串是否为回文串
        boolean[][] dp = new boolean[n][n];
        // 初始化回文子串计数器
        int count = 0;

        // 遍历所有可能的子串长度
        for(int len = 1; len <= n; len++){
            // 遍历所有可能的子串的起始位置
            for(int i = 0; i < n - len + 1; i++){
                // 计算子串的结束位置
                int j = i + len  -1;
                // 当子串长度为1 时, 子串一定为回文串
                if(len == 1){
                    dp[i][j] = true;
                }
                // 当子串长度为2时, 只需要判断首尾字符是否相同
                else if(len == 2) {
                    dp[i][j] = s.charAt(i) == s.charAt(j);
                }

                // 对于更长的子串 首尾字符相同时 判断内部子串是否为回文串
                else{
                    dp[i][j] = s.charAt(i) == s.charAt(j) && dp[i+1][j-1];
                }

                // 如果当前子串是回文串 计数器加1
                if(dp[i][j]){
                    count ++;
                }
                
            }
        }

        // 返回回文子串的总数
        return count;
    }
}
相关推荐
王老师青少年编程7 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌
EQUINOX17 小时前
2026年码蹄杯 本科院校赛道&青少年挑战赛道提高组初赛(省赛)第一场,个人题解
算法
萝卜小白7 小时前
算法实习Day04-MinerU2.5-pro
人工智能·算法·机器学习
Liangwei Lin7 小时前
洛谷 P3133 [USACO16JAN] Radio Contact G
数据结构·算法
伟大的车尔尼8 小时前
搜索题目:地图分析
动态规划·广度优先搜索
weixin_513449968 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结
c++·人工智能·学习·算法·机器人
code_pgf8 小时前
Qwen2.5-VL 算法解析
人工智能·深度学习·算法·transformer
Code-keys8 小时前
Android Codec2 Filter 算法模块开发指南
android·算法·音视频·视频编解码
无忧智库8 小时前
低空经济新基建:构建低空飞行大数据中心与行业应用算法工厂的全景式蓝图(WORD)
算法
闻缺陷则喜何志丹9 小时前
【背包 组合】P7552 [COCI 2020/2021 #6] Anagramistica|普及+
c++·算法·背包·洛谷·组合