Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法)
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算法)的更多相关文章
- 5. Longest Palindromic Substring(最长回文子串 manacher 算法/ DP动态规划)
Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...
- [LeetCode] 5. Longest Palindromic Substring 最长回文子串
Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...
- [leetcode]5. Longest Palindromic Substring最长回文子串
Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...
- 【LeetCode】5. Longest Palindromic Substring 最长回文子串
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 公众号:负雪明烛 本文关键词:最长回文子串,题解,leetcode, 力扣,python ...
- LeetCode:Longest Palindromic Substring 最长回文子串
题目链接 Given a string S, find the longest palindromic substring in S. You may assume that the maximum ...
- lintcode :Longest Palindromic Substring 最长回文子串
题目 最长回文子串 给出一个字符串(假设长度最长为1000),求出它的最长回文子串,你可以假定只有一个满足条件的最长回文串. 样例 给出字符串 "abcdzdcab",它的最长回文 ...
- 1. Longest Palindromic Substring ( 最长回文子串 )
要求: Given a string S, find the longest palindromic substring in S. (从字符串 S 中最长回文子字符串.) 何为回文字符串? A pa ...
- 【翻译】Longest Palindromic Substring 最长回文子串
原文地址: http://articles.leetcode.com/2011/11/longest-palindromic-substring-part-i.html 转载请注明出处:http:// ...
- 005 Longest Palindromic Substring 最长回文子串
Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...
随机推荐
- WMI_COM_API
Win32_Processor // CPU 处理器 Win32_PhysicalMemory // 物理内存 Win32_Keyboard // 键盘 Win32_PointingDevice // ...
- CentOS下配置apache+gitweb
GitWeb支持多个版本库,可以对多个版本库进行目录浏览(包括历史版本),可以查看文件内容,查看提交历史,提供搜索及 RSS feed支持,也可以提供目录文件的打包下载等.可以看https://git ...
- TCP协议传输大文件读取时候的问题
TCP协议传输大文件读取时候的问题 大文件传不完的bug 我们在定义的时候定义服务端每次文件读取大小为10240, 客户端每次接受大小为10240 我们想当然的认为客户端每次读取大小就是10240而把 ...
- java一个类 继承HttpServlet 和实现Servlet区别
java一个类 继承HttpServlet 和实现Servlet区别 servlet 是一个接口,如果实现这个接口,那么就必须实现接口里面定义的所有方法 而HttpServlet实现了servlet接 ...
- 头部姿态估计 - OpenCV/Dlib/Ceres
基本思想 通过Dlib获得当前人脸的特征点,然后通过旋转平移标准模型的特征点进行拟合,计算标准模型求得的特征点与Dlib获得的特征点之间的差,使用Ceres不断迭代优化,最终得到最佳的旋转和平移参数. ...
- Docker入门(初级)
注意:命令基于centos7.5 一.什么是Docker? 通俗的理解,Docker就是虚拟机.但Docker不是虚拟机,Docker是对操作系统进行虚拟,而虚拟机是虚拟了一套或多套硬件,再在这虚拟的 ...
- spring使用thymeleaf
一.spring使用thymeleaf做解析器其实很简单,这是基于xml配置的方式 <?xml version="1.0" encoding="UTF-8" ...
- 用ECharts绘制Prometheus图表,实现类似Grafana的自定义Dashboard
大家一般都是用Grafana自定义Dashboard来监控Prometheus数据的,作者这次尝试用ECharts来绘制Prometheus数据图表,一方面可以减少依赖,另一方面可以将监控界面灵活 ...
- Ubuntu下Mongo的安装和笔记
在linux下的安装 打开https://www.mongodb.com/download-center#community选择linux然后选择自己的Version复制DOWNLOAD旁边的链接 打 ...
- JDBC连接池-C3P0连接
JDBC连接池-C3P0连接 c3p0连接池的学习英语好的看英文原版 c3p0 - JDBC3 Connection and Statement Pooling 使用c3p0连接池 三种方 ...