题目

给出一个字符串(假设长度最长为1000),求出它的最长回文子串,你可以假定只有一个满足条件的最长回文串。

样例

给出字符串 "abcdzdcab",它的最长回文子串为 "cdzdc"

挑战

O(n2) 时间复杂度的算法是可以接受的,如果你能用 O(n) 的算法那自然更好。

解题

遍历字符串所有位置,对每个位置左右对等的找回文串,主要要分为两种形式

1.bab形式

2.bb形式

对找到的回文串保留最长的那个就是答案

public class Solution {
/**
* @param s input string
* @return the longest palindromic substring
*/
public String longestPalindrome(String s) {
// Write your code here
if( s == null || s.length() == 1)
return s;
String res = "";
int longest = Integer.MIN_VALUE;
for(int i = 1;i<s.length(); i++){
String str1 = longPalindrome(s,i,i);
String str2 = longPalindrome(s,i-1,i);
str1 = str2.length() >= str1.length()? str2:str1;
if(str1.length()>=longest){
res = str1;
longest = str1.length();
}
}
return res;
}
public String longPalindrome(String s,int start,int end){
int tmp1 = start;
int tmp2 = end;
while( start <= end && end<s.length() && start>=0 && s.charAt(start) == s.charAt(end) ){
start--;
end++;
}
// 没有进行while循环 说明不是回文串,这里只返回第start个字符
if(start ==tmp1 && end == tmp2)
return s.substring(start,start+1);
// start 多减了1
return s.substring(start + 1,end);
}
}

Java Code

总耗时: 19565 ms

class Solution:
# @param {string} s input string
# @return {string} the longest palindromic substring
def longestPalindrome(self, s):
# Write your code here
res = ""
longest = -1
if s == None or len(s) == 1:
return s
for i in range(1,len(s)):
res1 = self.longPalindrome(s,i,i)
res2 = self.longPalindrome(s,i-1,i)
if len(res1)> len(res2) and len(res1)>longest:
res = res1
longest = len(res1)
elif len(res2)> len(res1) and len(res2) >longest:
res = res2
longest = len(res2)
return res
def longPalindrome(self,s,start,end):
tmp1 = start
tmp2 = end
while start>=0 and end<len(s) and s[start] == s[end]:
start-=1
end +=1
if tmp1==start and tmp2 == end:
return s[start]
return s[(start+1):end]

Python Code

总耗时: 865 ms

动态规划

参考链接

定义二维数组table ,当table[i][j] =1 时候表示字符串str中i--j部分是回文串

table[i+1][j-1] == 1 && s.charAt(i) == s.charAt(j)
=>
table[i][j] == 1
初始化:table[i][i] = 1
public class Solution {
/**
* @param s input string
* @return the longest palindromic substring
*/
public String longestPalindrome(String s) {
// Write your code here
if( s == null || s.length() == 1)
return s;
String res = "";
int longest = Integer.MIN_VALUE;
int n = s.length();
int[][] table = new int[n][n];
for(int i=0;i<n;i++){
table[i][i] = 1;
}
for(int l=0;l<n;l++){
for(int i=0;i<n-l;i++){
int j = i+ l;
if( (j-i<=2 || table[i+1][j-1] == 1) && s.charAt(i)==s.charAt(j)){
table[i][j] =1;
if(j-i+1 > longest){
longest = j - i + 1;
res = s.substring(i,j+1);
}
}
}
}
return res;
}
}

j-i<=2 不明白


lintcode :Longest Palindromic Substring 最长回文子串的更多相关文章

  1. Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法)

    Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法) Given a string s, find the longest pal ...

  2. LeetCode:Longest Palindromic Substring 最长回文子串

    题目链接 Given a string S, find the longest palindromic substring in S. You may assume that the maximum ...

  3. [leetcode]5. Longest Palindromic Substring最长回文子串

    Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...

  4. 5. Longest Palindromic Substring(最长回文子串 manacher 算法/ DP动态规划)

    Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...

  5. [LeetCode] 5. Longest Palindromic Substring 最长回文子串

    Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...

  6. 【LeetCode】5. Longest Palindromic Substring 最长回文子串

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 公众号:负雪明烛 本文关键词:最长回文子串,题解,leetcode, 力扣,python ...

  7. 1. Longest Palindromic Substring ( 最长回文子串 )

    要求: Given a string S, find the longest palindromic substring in S. (从字符串 S 中最长回文子字符串.) 何为回文字符串? A pa ...

  8. 【翻译】Longest Palindromic Substring 最长回文子串

    原文地址: http://articles.leetcode.com/2011/11/longest-palindromic-substring-part-i.html 转载请注明出处:http:// ...

  9. LeetCode5. Longest Palindromic Substring 最长回文子串 4种方法

    题目链接:https://leetcode.com/problems/longest-palindromic-substring/ 题意很简单,就是求一个字符串得最长子串,这里的子串指连续的. 本文给 ...

随机推荐

  1. Mysql数据库常用的命令 数据备份 恢复 远程

    远程数据库 格式: mysql -h主机地址 -u用户名 -p用户密码数据库 mysql -h 42.51.150.68 -u yang -p discuz mysql设置密码 mysql>us ...

  2. Messagebox.Show()常用参数设置

    private void button1_Click(object sender, EventArgs e) { MessageBox.Show(" 1 个参数 " ); } pr ...

  3. [大牛翻译系列]Hadoop(10)MapReduce 性能调优:诊断reduce性能瓶颈

    6.2.3 Reduce的性能问题 Reduce的性能问题有和map类似的方面,也有和map不同的方面.图6.13是reduce任务的具体的执行各阶段,标识了可能影响性能的区域. 这一章将介绍影响re ...

  4. Win10环境下的Scrapy结合Tor进行匿名爬取

    本文内容来源:http://blog.privatenode.in/torifying-scrapy-project-on-ubuntu/ 在使用Scrapy的时候,一旦进行高频率的爬取就容易被封IP ...

  5. 含有自增序列的表中使用truncate与delete的不同结果

    一个含有自增序列的表,使用delete跟truncate之后会有什么不同结果呢? 大概说一下,使用truncate,表中的记录全部被清除,如果向表中插入数据,那么数据的排序是从1开始的. 如果使用的是 ...

  6. Makefile之wildcard

    1.wildcard : 扩展通配符2.notdir : 去除路径3.patsubst :替换通配符 例子:建立一个测试目录,在测试目录下建立一个名为sub的子目录$ mkdir test$ cd t ...

  7. Splitter

    <!DOCTYPE html> <html> <head> <title>PDemo</title> </head> <b ...

  8. linux内核源码注解

    轻松学习Linux操作系统内核源码的方法 针对好多Linux 爱好者对内核很有兴趣却无从下口,本文旨在介绍一种解读linux内核源码的入门方法,而不是解说linux复杂的内核机制:一.核心源程序的文件 ...

  9. 微软职位内部推荐-Enterprise Architect - BDE - BJ

    微软近期Open的职位: Enterprise ArchitectCloud, HTML5, Big Data and Mobile are technology trends driving pro ...

  10. 设计模式之原型模式(Prototype)

    1.出现原因 在软件系统中,经常面临着“某些结构复杂的对象”的创建工作:由于需求的变化,这些对象经常面临着剧烈的变化,但是它们却拥有比较稳定一致的接口. 如何应对这种变化?如何向“客户程序(使用这些对 ...