[译]最长回文字符串

原文链接: Longest Palindromic Substring

找到最长回文字符串是一个经典的编码面试问题,本文总结了针对这个问题的3中不同的解决方案。

  1. 动态程序
    让s成为输入字符串,i和j是字符串的两个索引。定义一个二维数组“table”,让table[i][j]表示从i到j的子字符串是否为回文。

更改条件:

table[i+1][j-1] == 1 && s.charAt(i) == s.charAt(j)
=>
table[i][j] == 1

时间 O(n^2) 空间 O(n^2)

public String longestPalindrome(String s) {
    if(s==null || s.length()<=1)
        return s;
 
    int len = s.length();
    int maxLen = 1;
    boolean [][] dp = new boolean[len][len];
 
    String longest = null;
    for(int l=0; l<s.length(); l++){
        for(int i=0; i<len-l; i++){
            int j = i+l;
            if(s.charAt(i)==s.charAt(j) && (j-i<=2||dp[i+1][j-1])){
                dp[i][j]=true;
 
                if(j-i+1>maxLen){
                   maxLen = j-i+1; 
                   longest = s.substring(i, j+1);
                }
            }
        }
    }
 
    return longest;
}

例如, 如果输入字符串是"dabcba", 最终的矩阵如下:

1 0 0 0 0 0 
0 1 0 0 0 1 
0 0 1 0 1 0 
0 0 0 1 0 0 
0 0 0 0 1 0 
0 0 0 0 0 1 

从表中,我们可以清楚地看到,最长的字符串是table[1][5]。

  1. 简单的算法
    时间 O(n^2), 空间 O(1)
public String longestPalindrome(String s) {
    if (s.isEmpty()) {
        return null;
    }
 
    if (s.length() == 1) {
        return s;
    }
 
    String longest = s.substring(0, 1);
    for (int i = 0; i < s.length(); i++) {
        // get longest palindrome with center of i
        String tmp = helper(s, i, i);
        if (tmp.length() > longest.length()) {
            longest = tmp;
        }
 
        // get longest palindrome with center of i, i+1
        tmp = helper(s, i, i + 1);
        if (tmp.length() > longest.length()) {
            longest = tmp;
        }
    }
 
    return longest;
}
 
// Given a center, either one letter or two letter, 
// Find longest palindrome
public String helper(String s, int begin, int end) {
    while (begin >= 0 && end <= s.length() - 1 && s.charAt(begin) == s.charAt(end)) {
        begin--;
        end++;
    }
    return s.substring(begin + 1, end);
}
  1. 曼切尔算法
    尽管它将带来O(n)时间复杂度的好处,但曼切尔算法的计算要复杂得多。因为它不是典型的,所以没有必要浪费时间。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 最长回文子串——Manacher 算法 1. 问题定义 最长回文字符串问题:给定一个字符串,求它的最长回文子串长度...
    林大鹏阅读 7,784评论 0 6
  • 上一篇KMP算法之后好几天都没有更新,今天介绍最长回文子串。 首先介绍一下什么叫回文串,就是正着读和倒着读的字符顺...
    zero_sr阅读 7,468评论 2 8
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,358评论 0 33
  • 问题定义 最长回文子串问题:给定一个字符串,求它的最长回文子串长度。 解法1:暴力解法 找到字符串的所有子串,判断...
    HITMiner阅读 4,026评论 0 2
  • 沉浸:尽你所能阅读、研究和学习关于该问题的一切内容。 构思:从各角度看问题,开发点子,提出尽可能多的可选方案。 困...
    lubinghu12阅读 2,849评论 0 1

友情链接更多精彩内容