【算法五十二】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)

相关推荐
水蓝烟雨6 小时前
0135. 分发糖果
算法·leetcode
Lewiis6 小时前
白话选择排序
数据结构·算法·排序算法
计算机安禾6 小时前
【算法分析与设计】第19篇:二分图匹配与指派问题
大数据·人工智能·算法
学习中.........6 小时前
从傅里叶级数到傅里叶变换:详细的数学推导
算法
宇宙realman_9996 小时前
420B污染度等级查询代码
java·开发语言·算法
Dfreedom.6 小时前
深度学习量化技术全景解析:从校准算法到量化算子的完整指南
人工智能·深度学习·算法·量化·模型加速
如竟没有火炬7 小时前
乘法表中第K小的数——二分
开发语言·数据结构·python·算法·leetcode·职场和发展·动态规划
2401_876964137 小时前
27考研李艳芳网课|王谱2027数学讲义
人工智能·经验分享·深度学习·考研·算法·计算机视觉·概率论
努力的小张.7 小时前
最大子段和(前缀和解决)
算法