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

Given a string s, find the longest palindromic substring in s. You may assume that the maximum length of s is 1000.

Example 1:

Input: "babad"
Output: "bab"
Note: "aba" is also a valid answer.

Example 2:

Input: "cbbd"
Output: "bb"

题解:

这个题重新学习了Manacher算法,重新研读第一次学习的代码,真正把这个题的思路想清楚,就可以按照理解很快的把代码实现出来,比我第一次学习这个算法的时候看懂别人的代码然后把别人的模板抄下来,进步了很多。

这个题给我的启发也是,学习任何算法,思考清楚整个过程然后再自己实现它,思考的过程长一点,理解好每个细节是很重要的,只有想明白才能很快把代码写出来!以后要养成没有思考清楚就不着急下手敲题的习惯。

Manacher算法:是一个很典型的空间换时间的算法,给出我初次学习的笔记https://www.cnblogs.com/shanyr/p/5676597.html

  重新梳理以下这个算法:

  算法主要分为三部分:

  A. 扩展原字符串:

    a.为了防止遍历到起始位置的时候会出现越界的情况,在最开始添加字符“$”(我是用手动判度是否到到结尾的,如果不加这个判断我感觉也可以在结尾加一个‘$’)

    b.将每个字符用未出现过的字符隔开,一般用‘#’

       根据前两步,一个字符串会变成下面的形式

    b a b a d

       ->$#b#a#b#a#d#

  B. 变量定义:

    a.定义p[i]表示从第i个位置可以向两边延伸的最长的位置,使得以i为中心,左右各扩展p[i]长度的子串满足回文

     例如对串$#b#a#b#a#d#的p数组为

            $ #  b # a  # b  # a # d #

    p  ->  0  0 1  0 3  0 3  0 1 0  1 0

     然后可以发现p中的最大值就是最长回文子串的长度,很容易证明。但是这个题要求输出的是子串,只要从最大值为中心,前后p[]的位置搜索,把不是'#'输出就可以。

  C. 求p[i]:由于我们是O(n)的算法,所以在计算第i个位置的时候,前面的i-1个位置的p值已经算出来了。

    我们可以利用之前求的对称性:定义mx为当前扫描的最远的位置,id为mx对应的中心点,可以将p[i]分成两种情况求解:

    a. 情况1,如下图所示,mx-i >p[j],那么p[i]一定等于p[j]。(因为id左右mx是对称的)

    b.情况2,如下图所示,mx-i <= p[j],那么mx-i的长度的部分一定是对称的,但是超出的部分就要挨个判断了,判断结束后要更新mx = i+p[i], id = i。(因为id左右mx是对称的)

 

给出代码:

 class Solution {
public:
string longestPalindrome(string s) {
//扩展
string expend_s;
expend_s+='$';
int len = s.length();
for(int i = ; i < len; i++){
expend_s+='#';
expend_s+=s[i];
}
expend_s+='#';
//定义
int p[*expend_s.length()];
memset(p,,sizeof(p));
int mx = , id = ;
int max = , maxid = ;//保存最大回味子串搜索长度和位置
//求p
for(int i = ; i < expend_s.length(); i++){
int j = *id - i;
if(p[j]<mx-i){
p[i] = p[j];
}
else{
for(;expend_s[i+p[i]]==expend_s[i-p[i]]; p[i]++){
if(i+p[i]>=expend_s.length())break;//要判断右侧是否越界
}
mx = i+p[i];
id = i;
}
if(max < p[i]){
max = p[i];
maxid = i;
}
}
string ans;
for(int i = maxid-max+; i <= maxid+max-; i++){
if(expend_s[i]!='#'){
ans+=expend_s[i];
}
}
return ans;
}
};

  


Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法)的更多相关文章

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

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

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

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

  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. 【LeetCode】5. Longest Palindromic Substring 最长回文子串

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

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

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

  6. lintcode :Longest Palindromic Substring 最长回文子串

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

  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. 005 Longest Palindromic Substring 最长回文子串

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

随机推荐

  1. Android/AndroidStudio/idea使用教程之git使用(详细)(码云)

    已经安装好了AndroidStudio,安装教程 本教程是作者自己摸索出来的,有不足之处还请大家海涵.多多拍砖,互相学习. 第一步:下载git,安装git客户端 直接百度git,下载git ​ 安装g ...

  2. C#3.0新增功能09 LINQ 基础06 LINQ 查询操作中的类型关系

    连载目录    [已更新最新开发文章,点击查看详细] 若要有效编写查询,应了解完整的查询操作中的变量类型是如何全部彼此关联的. 如果了解这些关系,就能够更容易地理解文档中的 LINQ 示例和代码示例. ...

  3. 多个module实体类集合打一个jar包并上传至远程库

    本章内容主要分享多个module中的实体类集合生成到一个jar包中,并且发布到远程库:这里采用maven-assembly-plugin插件的功能来操作打包,内容不长却贴近实战切值得拥有,主要节点内容 ...

  4. C 单链表 实现约瑟夫环

    list.h #ifndef _List_H #define _List_H typedef int ElementType; struct Node; typedef struct Node *Pt ...

  5. Windows cmd用语

    windows cmd用语.    shutdown: -l 注销                               -s 关闭计算机                             ...

  6. Java基础之十五 泛型

    第十五章 泛型 一般的类和方法,只能使用具体的类型:要么是基本类型,要么是自定义类型.如果要编写可以应用于多种类型的代码,这种刻板的限制对代码的束缚就会很大. 在面对对象编程语言中,多态算是一种泛化机 ...

  7. oracle的开窗函数

    原创 select * from (select province, commodity, sum(price), ROW_NUMBER() OVER(PARTITION BY province  o ...

  8. 向.Net/Unity 程序员推荐一个十分因吹斯听的网站:sharplab.io

    0x00 前言 & 过程 & 结论 今天发现了一个十分有趣的网站: https://sharplab.io/ 网站的页面并不复杂,功能大体上能够在题图中得到概括.发现它的过程也很偶然, ...

  9. Java编程基础阶段笔记 day 07 面向对象编程(上)

    ​ 面向对象编程 笔记Notes 面向对象三条学习主线 面向过程 VS 面向对象 类和对象 创建对象例子 面向对象的内存分析 类的属性:成员变量 成员变量 VS 局部变量 类的方法 方法的重载 可变个 ...

  10. Java课堂 动手动脑5

    1.了解棋盘打印:利用二维数组输出一个15*15的棋盘,棋盘的原素为“+”,就是输出一个横纵都是15个“+”的二维数组,然后再以坐标形式输入棋子“●”,替换掉原来棋盘里的“+”.再编写代码. 电脑随机 ...