刷题训练 day49 | 第九章 动态规划 part17

题目1:

java 复制代码
class Solution {
    public int countSubstrings(String s) {
        boolean[][] dp = new boolean[s.length()][s.length()];
        int result=0;
        for(int i=dp.length-1;i>=0;i--){
            for (int j=i;j<dp[0].length;j++){
                 if (s.charAt(i)==s.charAt(j)){
                    if (j-i<=1){
                       dp[i][j]=true;
                       result++;
                    }else if (dp[i+1][j-1]==true){
                       dp[i][j]=true;
                       result++;
                    }
                 }
            }
        }
        return result;
    }
}

题目2:

java 复制代码
public class Solution {
    public int longestPalindromeSubseq(String s) {
        int len = s.length();
        int[][] dp = new int[len + 1][len + 1];
        for (int i = len - 1; i >= 0; i--) { // 从后往前遍历 保证情况不漏
            dp[i][i] = 1; // 初始化
            for (int j = i + 1; j < len; j++) {
                if (s.charAt(i) == s.charAt(j)) {
                    dp[i][j] = dp[i + 1][j - 1] + 2;
                } else {
                    dp[i][j] = Math.max(dp[i + 1][j], Math.max(dp[i][j], dp[i][j - 1]));
                }
            }
        }
        return dp[0][len - 1];
    }
}
相关推荐
我家领养了个白胖胖几秒前
SSE在Spring ai alibaba中同时使用Qwen和DeepSeek模型
java·后端·ai编程
仰泳的熊猫6 分钟前
1112 Stucked Keyboard
数据结构·c++·算法·pat考试
roman_日积跬步-终至千里11 分钟前
【计算机算法与设计(14)】例题五:最小生成树:Prim算法详细解释:π的含义、更新逻辑和选点原因
算法
让学习成为一种生活方式11 分钟前
压缩文件夹下下所有文件成压缩包tar.gz--随笔016
算法
AI科技摆渡13 分钟前
GPT-5.2介绍+ 三步对接教程
android·java·gpt
嗷嗷哦润橘_17 分钟前
AI Agent学习:MetaGPT项目之RAG
人工智能·python·学习·算法·deepseek
猿与禅20 分钟前
Spring Boot 4.0 完整核心特性及实践指南
java·spring boot·后端·spring·重大升级·springboot4.0
运维@小兵34 分钟前
Spring-AI系列——Tool Calling获取当前时间
java·后端·spring
不忘不弃35 分钟前
指针元素的使用
算法
认真敲代码的小火龙36 分钟前
【JAVA项目】基于JAVA的养老院管理系统
java·开发语言·课程设计