200.Longest Palindromic Substring-最长回文子串(中等题)

本文介绍了一种高效的寻找字符串中最长回文子串的方法,使用Manacher算法实现O(n)的时间复杂度,通过实例解释了算法的具体实现过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最长回文子串

  1. 题目

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

  2. 样例

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

  3. 挑战

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

  4. 题解

    Manacher算法,时间复杂度为O(n)。

public class Solution {
    /**
     * @param s input string
     * @return the longest palindromic substring
     */
    public String longestPalindrome(String s) {
        if (s == null || s.length() == 0) 
        {
            return "";
        }

        int length = s.length();    
        int max = 0;
        String result = "";
        for(int i = 1; i <= 2 * length - 1; i++)
        {
            int count = 1;
            while(i - count >= 0 && i + count <= 2 * length  && get(s, i - count) == get(s, i + count))
            {
                count++;
            }
            count--; 
            if(count > max) 
            {
                result = s.substring((i - count) / 2, (i + count) / 2);
                max = count;
            }
        }

        return result;
    }

    private char get(String s, int i) 
    {
        return i % 2 == 0 ? '#' : s.charAt(i / 2);
    }
}

Last Update 2016.11.2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值