[译]最长回文字符串

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

原文链接: 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)时间复杂度的好处,但曼切尔算法的计算要复杂得多。因为它不是典型的,所以没有必要浪费时间。
目录
相关文章
|
7月前
|
机器学习/深度学习 算法 JavaScript
【动态规划】【回文】【字符串】1278分割回文串 III
【动态规划】【回文】【字符串】1278分割回文串 III
|
7月前
|
机器学习/深度学习 测试技术 Windows
【动态规划】【回文】【字符串】1147. 段式回文
【动态规划】【回文】【字符串】1147. 段式回文
|
6月前
|
人工智能 算法
最长公共子串
最长公共子串
53 2
|
6月前
14. 最长公共前缀
14. 最长公共前缀
|
7月前
|
机器学习/深度学习 算法 测试技术
【字符串】【分类讨论】【KMP】1163. 按字典序排在最后的子串
【字符串】【分类讨论】【KMP】1163. 按字典序排在最后的子串
|
7月前
14.最长公共前缀
14.最长公共前缀
41 0
|
7月前
|
Python
ptthon字符串的逆序输出
字符串的逆序输出
42 0
|
7月前
|
C++
最长公共前缀(C++)
最长公共前缀(C++)
49 0
|
7月前
|
存储 算法 程序员
【算法训练-字符串 一】【子串问题】最长无重复子串、最长回文子串、最长公共前缀
【算法训练-字符串 一】【子串问题】最长无重复子串、最长回文子串、最长公共前缀
70 0
|
算法 前端开发 JavaScript
[LeetCode] 无重复字符的最长子串 & 最长回文子串
博主最近在看新的工作机会,也是在找一些leetcode上比较高频的算法复习一下,这里分享两道算法题的解题。
72 2
[LeetCode] 无重复字符的最长子串 & 最长回文子串