Leetcode5:最长回文子串

题目地址:. - 力扣(LeetCode)

题目描述:

给你一个字符串 s,找到 s 中最长的回文子串。

示例 1:

复制代码
输入:s = "babad"
输出:"bab"
解释:"aba" 同样是符合题意的答案。

示例 2:

复制代码
输入:s = "cbbd"
输出:"bb"

提示:

  • 1 <= s.length <= 1000
  • s 仅由数字和英文字母组成

解题思路

这段代码是用来找出一个字符串中最长的回文子串。回文是一个正读和反读都相同的字符串。这个解决方案的核心思想是中心扩展法。它主要分为以下几个步骤:

  1. 边界条件 :如果字符串s为空或者长度小于2,那么直接返回s,因为单个字符或者空字符串本身就是一个回文。

  2. 初始化变量resIdx用来记录最长回文子串的起始索引,resLen用来记录最长回文子串的长度。

  3. 遍历字符串 :使用一个循环遍历字符串s中的每个字符(除了最后一个字符,因为最后一个字符单独不能形成回文)。

  4. 奇数长度回文 :对于每个索引idx,首先尝试找到以idxidx+1为中点的最长奇数长度回文子串。这是通过longestLen方法实现的,该方法从中心向两边扩展,直到不满足回文条件。

  5. 偶数长度回文 :然后尝试找到以idx为中点的最长偶数长度回文子串。

  6. 更新结果 :如果找到的回文子串长度大于当前记录的最长长度resLen,则更新resLenresIdx

  7. 返回结果 :最后,使用substring方法根据resIdxresLen截取最长回文子串并返回。

代码:

复制代码
class Solution {
    public String longestPalindrome(String s) {
        // 如果字符串为空或者只有一个字符,直接返回该字符串
        if (s == null || s.length() < 2) return s;
        
        int resIdx = 0, resLen = 1; // 初始化最长回文子串的起始索引和长度
        for (int idx = 0; idx < s.length() - 1; idx++) {
            // 尝试找到以当前字符为中心的最长奇数长度回文子串
            int len1 = longestLen(s, idx, idx);
            // 尝试找到以当前字符和下一个字符为中心的最长偶数长度回文子串
            int len2 = longestLen(s, idx, idx + 1);
            
            // 如果找到的奇数长度回文子串比当前记录的最长回文子串长,则更新结果
            if (len1 > resLen) {
                resLen = len1;
                resIdx = idx - resLen / 2;
            }
            // 如果找到的偶数长度回文子串比当前记录的最长回文子串长,则更新结果
            if (len2 > resLen) {
                resLen = len2;
                resIdx = idx - (resLen / 2 - 1);
            }
        }
        // 返回找到的最长回文子串
        return s.substring(resIdx, resIdx + resLen);
    }
    
    /**
     * 从给定的左右边界向左和右探索,找到最长的回文子串长度
     *
     * @param s 字符串
     * @param left 左边界索引
     * @param right 右边界索引
     * @return 最长回文子串的长度
     */
    private int longestLen(String s, int left, int right) {
        while (left >= 0 && right < s.length()) {
            // 如果左右边界对应的字符不相等,则跳出循环
            if (s.charAt(left) != s.charAt(right)) break;
            // 否则,向左和右扩展边界
            left--;
            right++;
        }
        // 返回找到的最长回文子串长度
        // right - left - 1 是因为while循环中left和right已经多减了1
        return right - left - 1;
    }
}

时间复杂度

时间复杂度是分析算法性能的一个重要指标,它描述了算法执行时间随输入规模增长的变化趋势。

  • 对于每个字符,我们最多会进行两次longestLen调用(一次是奇数长度回文,一次是偶数长度回文)。
  • longestLen方法中,最坏情况下会进行O(n)次迭代,其中n是字符串的长度。
  • 因此,总的时间复杂度是O(n^2),其中n是字符串的长度。

总结信息

这段代码实现了一个有效的算法来找出一个字符串中的最长回文子串。它使用了中心扩展法,这种方法的时间复杂度是O(n^2),其中n是字符串的长度。这种方法的优点是它不需要额外的存储空间来存储回文子串,因此空间复杂度是O(1)。此外,这种方法也很容易实现,并且对于大多数实际应用来说,其性能已经足够好。然而,对于非常大的字符串,可能需要更高效的算法,比如Manacher算法,它的时间复杂度可以达到O(n)

相关推荐
Codebee6 分钟前
OneCode图生代码技术深度解析:从可视化设计到注解驱动实现的全链路架构
css·人工智能·算法
刘大猫269 分钟前
Datax安装及基本使用
java·人工智能·算法
Gyoku Mint3 小时前
深度学习×第4卷:Pytorch实战——她第一次用张量去拟合你的轨迹
人工智能·pytorch·python·深度学习·神经网络·算法·聚类
葫三生4 小时前
如何评价《论三生原理》在科技界的地位?
人工智能·算法·机器学习·数学建模·量子计算
拓端研究室6 小时前
视频讲解:门槛效应模型Threshold Effect分析数字金融指数与消费结构数据
前端·算法
随缘而动,随遇而安8 小时前
第八十八篇 大数据中的递归算法:从俄罗斯套娃到分布式计算的奇妙之旅
大数据·数据结构·算法
IT古董9 小时前
【第二章:机器学习与神经网络概述】03.类算法理论与实践-(3)决策树分类器
神经网络·算法·机器学习
水木兰亭12 小时前
数据结构之——树及树的存储
数据结构·c++·学习·算法
Jess0713 小时前
插入排序的简单介绍
数据结构·算法·排序算法
老一岁13 小时前
选择排序算法详解
数据结构·算法·排序算法