刷题训练 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];
    }
}
相关推荐
liujing102329292 分钟前
Day09_刷题niuke20250609
java·c++·算法
无奈何杨3 分钟前
事件时间驱动的策略版本管理:风控系统中的关键设计抉择
java·后端·架构
不7夜宵5 分钟前
力扣热题100 k个一组反转链表题解
算法·leetcode·链表
程序员JerrySUN24 分钟前
Linux 内核内存管理子系统全面解析与体系构建
java·linux·运维
风象南38 分钟前
SpringBoot的5种签到打卡实现方案
java·spring boot·后端
1candobetter44 分钟前
JAVA后端开发——多租户
java·开发语言
蒟蒻小袁1 小时前
力扣面试150题--课程表
算法·leetcode·面试
闻缺陷则喜何志丹1 小时前
【动态规划】B4336 [中山市赛 2023] 永别|普及+
c++·算法·动态规划·洛谷
星辰离彬1 小时前
Java 高级泛型实战:8 个场景化编程技巧
java·开发语言·后端·程序人生