package string.string1_6;

public class LongestPalidrome
{
/**
* 使用常规方法, 以字符串的每一个字符作为中心进行判断, 包括奇数和偶数的情况
* 最坏时间复杂度为O(N^2) , 空间复杂度O(1)
*/
public static int longestPalidrome(String s)
{
if(s == null || s.length() <= 0)
return 0 ; int max = 0 ; for(int i=0 ; i<s.length() ; i++)
{
for(int time=0 ; time<2 ; time++)
{
int length = getMax(s , i , time+i) ;
if(max < length)
max = length ;
}
} return max ;
} private static int getMax(String s, int left , int right) {
while (left >= 0 && right <= s.length() - 1) {
if (s.charAt(left) != s.charAt(right))
break;
left--;
right++;
} return right - left - 1;
} /**
* 使用manacher算法(其实就是动态规划的一种情况)
* 时间复杂度O(N), 空间复杂度O(N)
*/
public static int longestPalidrome2(String s)
{
if(s == null || s.length() < 1)
return 0 ;
String judge = init(s) ; int id = 0 ; //最大回文的中心
int mx = 0 ; //为id+p[id], 也就是最大回文的后半段
int[] p = new int[judge.length()] ; for(int i=1 ; i<judge.length()-1 ; i++)
{
if(i < mx)
{
p[i] = min(p[2*id-i] , mx-i) ; //对p[i]进行预测
}
else
{
p[i] = 1 ; //无法使用之前的结论进行预测, 因此只能先假设p[i]只为该元素本身的长度1.
} while (judge.charAt(i-p[i]) == judge.charAt(i+p[i])) //在mx外是否仍存在回文
p[i]++ ; //更新mx和id
if(p[i]+i-1 > mx)
{
mx = p[i] + i -1;
id = i ;
}
} int mxId = 0 ;
for(int i=1 ; i<p.length ; i++)
{
if(p[i] > p[mxId])
mxId = i ;
} return p[mxId]-1 ;
} /**
* 预处理:将原来的字符串str填充为为$#...#*的格式
* 由于java没有\0作为字符串的结束标志, 因此在结尾使用*作为结束标志
* 其中的$和*是用来当哨兵的
*/
private static String init(String str)
{
StringBuilder sb = new StringBuilder(str.length()*2+2) ; sb.append("$#") ;
for(int i=0 ; i<str.length() ; i++)
{
sb.append(str.charAt(i)).append("#") ;
} sb.append("*") ;
return sb.toString() ;
}
private static int min(int a , int b)
{
return a > b ? b : a ;
} public static void main(String[] args)
{
//dsjfkldsababasdlkfjsd
//skjflkdsjfkldsababasdlkfjsdwieowowwpw
String str = "a"; System.out.println(longestPalidrome2(str));
}
}

参考://https://yq.aliyun.com/articles/3739

java 最长回文字串的更多相关文章

  1. 求字符串的最长回文字串 O(n)

    昨天参加了某公司的校园招聘的笔试题,做得惨不忍睹,其中就有这么一道算法设计题:求一个字符串的最长回文字串.我在ACM校队选拔赛上遇到过这道题,当时用的后缀数组AC的,但是模板忘了没写出代码来. 回头我 ...

  2. hihocoder 第一周 最长回文字串

    题目1 : 最长回文子串 时间限制:1000ms 单点时限:1000ms 内存限制:64MB 描述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相帮助,在编程 ...

  3. POJ 3974 最长回文字串(manacher算法)

    题意:给出一个字符串,求出最长回文字串. 思路:一开始我直接上了后缀数组DC3的解法,然后MLE了.看了DISCUSS发现还有一种计算回文字串更加优越的算法,就是manacher算法.就去学习了一下, ...

  4. 最长回文字串——manacher算法

    时间复杂度:O(n) 参考:https://segmentfault.com/a/1190000003914228 1.问题定义 最长回文子串问题:给定一个字符串,求它的最长回文子串长度. 如果一个字 ...

  5. Hdu 3068 最长回文字串Manacher算法

    题目链接 最长回文 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  6. 最长回文字串 (The longest palindrome substring)

    这两天去学了一下,觉得下面那篇文章写的很好,有例子,比较容易懂,所以转一下. 以下内容来自:hihoCoder: 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互 ...

  7. Leetcode5.Longest Palindromic Substring最长回文字串

    给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为1000. 示例 1: 输入: "babad" 输出: "bab" 注意: &quo ...

  8. 【POJ3974】最长回文字串

    在这里采用的是哈希+二分的方法. 根据回文串的性质可知,可以将回文分成奇回文和偶回文分别进行处理. 对于奇回文来说,每次枚举的端点一定是重合的,因此只需计算出端点左右公共的长度是多少即可,因此二分的是 ...

  9. 【LeetCode每天一题】Longest Palindromic Substring(最长回文字串)

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

随机推荐

  1. FZU Problem 2200 cleaning dp

    Problem Description N个人围成一圈在讨论大扫除的事情,需要选出K个人.但是每个人与他距离为2的人存在矛盾,所以这K个人中任意两个人的距离不能为2,他们想知道共有多少种方法. Inp ...

  2. linux内核设计与实现第一章

    1.1 unix的历史 Thompson实现unix 伯克利大学对其进一步开发推出了著名的BSD 其他各大厂商相继推出自己的unix 1.1.2 unix的特性 unix系统是一个强大,健壮,稳定的操 ...

  3. Python入门--16--模块

    模块的定义: 模块是一个包含所有你定义的函数和变量的文件,其后缀是.py.模块可以被别的程序引入,以使用该模块中的函数等功能 比如 import random secret=random.randin ...

  4. Nginx没有启动文件、nginx服务不支持chkconfig、nginx无法自启

    Nginx没有启动文件.nginx服务不支持chkconfig.nginx无法自启 问题描述: Nginx安装后,当想要设置Ngixn为开机启动时, 就需要把nginx的启动命令路径放到/etc/rc ...

  5. 解决npm 的 shasum check failed for错误

    使用npm安装一些包失败,类似如下报错情况:   C:\Program Files\nodejs>npm update npm npm ERR! Windows_NT 10.0.14393 np ...

  6. python笔记4:高级特性

    4 高级特性 4.1  切片 [:] *注:-- list和tuple,字符串都支持切片 4.2 迭代 Iteration for ... in 及 for ... in if 两个变量迭代时, 例1 ...

  7. Codeforces 149D Coloring Brackets(树型DP)

    题目链接 Coloring Brackets 考虑树型DP.(我参考了Q巨的代码还是略不理解……) 首先在序列的最外面加一对括号.预处理出DFS树. 每个点有9中状态.假设0位不涂色,1为涂红色,2为 ...

  8. Codeforces 246E Blood Cousins Return(树上启发式合并)

    题目链接 Blood Cousins Return #include <bits/stdc++.h> using namespace std; #define rep(i, a, b) f ...

  9. [翻译] NumSharp的数组切片功能 [:]

    原文地址:https://medium.com/scisharp/slicing-in-numsharp-e56c46826630 翻译初稿(英文水平有限,请多包涵): 由于Numsharp新推出了数 ...

  10. 洛谷——P1144 最短路计数

    P1144 最短路计数 题目描述 给出一个N个顶点M条边的无向无权图,顶点编号为1-N.问从顶点1开始,到其他每个点的最短路有几条. 输入输出格式 输入格式: 输入第一行包含2个正整数N,M,为图的顶 ...