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);

    }

 
}
相关推荐
Dylan的码园10 分钟前
从软件工程师看计算机是如何工作的
java·jvm·windows·java-ee
额,不知道写啥。11 分钟前
P5314 ODT(毒瘤树剖)
数据结构·c++·算法
CHANG_THE_WORLD12 分钟前
深入指针5:回调函数与泛型排序
数据结构·算法
今儿敲了吗17 分钟前
24| 字符串
数据结构·c++·笔记·学习·算法
callJJ17 分钟前
Spring AI Tool Calling(工具调用)详解——让大模型拥有“动手能力“
java·人工智能·spring·spring ai·tool calling
南部余额21 分钟前
SpringBoot文件上传全攻略
java·spring boot·后端·文件上传·multipartfile
Wect29 分钟前
LeetCode 105. 从前序与中序遍历序列构造二叉树:题解与思路解析
前端·算法·typescript
小雨中_33 分钟前
2.5 动态规划方法
人工智能·python·深度学习·算法·动态规划
java1234_小锋1 小时前
Java高频面试题:什么是Redis哨兵机制?
java·redis·面试
智算菩萨1 小时前
【Python小游戏】基于Pygame的递归回溯迷宫生成与BFS寻路实战:从算法原理到完整游戏架构的深度解析
python·算法·pygame