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 分钟前
Java据结构深度解析:AVL 树与红黑树
数据结构·算法
feifeigo1238 分钟前
MATLAB中对转子建立有限元模型并进行动力学计算
算法
网域小星球9 分钟前
C 语言从 0 入门(十九)|共用体与枚举:自定义类型进阶
c语言·开发语言·算法·枚举·自定义类型·共用体
favour_you___14 分钟前
算法练习2026/4/13
算法·深度优先
吃着火锅x唱着歌18 分钟前
LeetCode 1963 使字符串平衡的最小交换次数
算法·leetcode·职场和发展
无敌昊哥战神24 分钟前
【算法与数据结构】深入浅出回溯算法:理论基础与核心模板(C/C++与Python三语解析)
c语言·数据结构·c++·笔记·python·算法
輕華26 分钟前
OpenCV三大传统人脸识别算法:EigenFace、FisherFace与LBPH实战
人工智能·opencv·算法
akarinnnn27 分钟前
【DAY16】字符函数和字符串函数
c语言·数据结构·算法
_日拱一卒33 分钟前
LeetCode:螺旋矩阵
算法·leetcode·矩阵
Tairitsu_H38 分钟前
C语言:排序(二)
c语言·开发语言·算法