Java中等题-最长回文子串(力扣)

给你一个字符串 s,找到 s 中最长的 回文子串。

示例1:

复制代码
输入:s = "babad"
输出:"bab"
解释:"aba" 同样是符合题意的答案。

示例 2:

复制代码
输入:s = "cbbd"
输出:"bb"

这道题我没有思路,所以直接看了官方解题思路,然后自己写了一遍:

动态规划:

java 复制代码
class Solution {
    public String longestPalindrome(String s) {
        int n=s.length();
        if(n<=1){
            return s;
        }
        int dp[][]=new int[n][n];
        for(int i=0;i<n;i++){
            dp[i][i]=1;
        }
        int max=1;
        int start=0;
        char[] chars = s.toCharArray();
        for(int i=2;i<=n;i++){
            for(int m=0;m<n;m++){
                int j=m+i-1;
                if(j>=n){
                    break;
                }
                if(chars[m]!=chars[j]){
                    dp[m][j]=0;
                    continue;
                }else if(m+1<=j-1&&chars[m]==chars[j]&&dp[m+1][j-1]!=0){
                    dp[m][j]=j-m+1;
                    if(dp[m][j]>max){
                        max=dp[m][j];
                        start=m;
                    }
                }else if(m+1==j){
                    dp[m][j]=j-m+1;
                    if(dp[m][j]>max){
                        max=dp[m][j];
                        start=m;
                    }
                }

            }
        }
        return s.substring(start, start + max);

    }

 
}
相关推荐
心月狐的流火号2 分钟前
Java CompletableFuture 核心API
java
黑客影儿12 分钟前
Java技术总监的成长之路(技术干货分享)
java·jvm·后端·程序人生·spring·tomcat·maven
京东云开发者17 分钟前
EXCEL导入—设计与思考
java·架构
Warren9826 分钟前
软件测试-Selenium学习笔记
java·javascript·笔记·学习·selenium·测试工具·安全
秋难降28 分钟前
LRU缓存算法(最近最少使用算法)——工业界缓存淘汰策略的 “默认选择”
数据结构·python·算法
tkevinjd35 分钟前
图论\dp 两题
leetcode·动态规划·图论
没有bug.的程序员1 小时前
JVM 运行时数据区详解:内存模型与对象生命周期全景解析
java·jvm·运行时数据区·内存模型·对象生命周期
一语长情1 小时前
Netty流量整形:保障微服务通信稳定性的关键策略
java·后端·架构
盖世英雄酱581362 小时前
第一个RAG项目遇到的问题
java·spring boot
最初的↘那颗心2 小时前
Flink Stream API - 源码开发需求描述
java·大数据·hadoop·flink·实时计算