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;
    }
}
相关推荐
小O的算法实验室18 分钟前
2026年SEVC,面向主动成像卫星任务规划问题的群体智能与动态规划混合框架,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
网安INF28 分钟前
数据结构第一章复习:基本概念与算法复杂度分析
数据结构·算法
幻风_huanfeng1 小时前
人工智能之数学基础:什么是凸优化问题?
人工智能·算法·机器学习·凸优化
三雷科技1 小时前
使用 `dlopen` 动态加载 `.so` 文件
开发语言·c++·算法
Yzzz-F1 小时前
Problem - 2146D1 - Codeforces &&Problem - D2 - Codeforces
算法
Kk.08021 小时前
力扣 LCR 084.全排列||
算法·leetcode·职场和发展
环黄金线HHJX.1 小时前
龙虾钳足启发的AI集群语言交互新范式
开发语言·人工智能·算法·编辑器·交互
Omics Pro1 小时前
虚拟细胞:开启HIV/AIDS治疗新纪元的关键?
大数据·数据库·人工智能·深度学习·算法·机器学习·计算机视觉
旖-旎2 小时前
分治(快速选择算法)(3)
c++·算法·leetcode·排序算法·快速选择
_日拱一卒2 小时前
LeetCode:合并区间
算法·leetcode·职场和发展