【算法五十二】5. 最长回文子串

5. 最长回文子串

动态规划:

java 复制代码
class Solution {
    public String longestPalindrome(String s) {
        //子问题:dp[i][j] 表示 s[i..j] 是否是回文子串
        //动态方程:dp[i][j] = s[i]==s[j] && (j-i<=2 || dp[i+1][j-1]==true)
        //范围i从大到小,因为计算dp[i][j]需要dp[i+1][j-1]

        int n = s.length();
        boolean[][] dp = new boolean[n][n];

        int start = 0;
        int maxLen = 1;

        for(int i=n-1;i>=0;i--){
            for(int j=i;j<n;j++){
                if(s.charAt(i) == s.charAt(j)){
                    if(j-i<=2 || dp[i+1][j-1]){
                        dp[i][j] = true;

                        int len = j-i+1;
                        if(len>maxLen){
                            maxLen = len;
                            start = i;
                        }
                        
                    }
                }
            }
        }
        return s.substring(start,start+maxLen);
    }

}

时间复杂度:O(N²)

空间复杂度:O(N²)

中心拓展法:

java 复制代码
class Solution {
    public String longestPalindrome(String s) {
        int n = s.length();
        int maxLen = 1;
        int start = 0;
        for(int i = 0;i<n;i++){
            //奇数向外扩展
            int len1 = expand(s,i,i);
            //偶数向外扩展
            int len2 = expand(s,i,i+1);

            int len = Math.max(len1,len2);
            if(len > maxLen){
                maxLen = len;
                //计算起点
                start = i-(len-1)/2;
            }
        }
        return s.substring(start,start+maxLen);
    }

    private int expand(String s,int l,int r){
        int n = s.length();
        while(l>=0 && r<=n-1 && s.charAt(l)==s.charAt(r)){
            l--;
            r++;
        }
        return r-l-1;
    }
}

时间复杂度:O(N²)

空间复杂度:O(1)

相关推荐
JieE21210 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21211 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术15 小时前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦16 小时前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户4978630507319 小时前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆2 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人