【马拉车算法/动态规划】最长回文字串

最长回文字串

1.问题描述

常用有3种算法:中心扩展法、动态规划和Manacher算法

2.中心扩展法(O(N^2))

解释:

从中心向外扩展。

分为两种情况:第一种当回文串长度为奇数的情况;第二种当回文串长度为偶数的情况。

左右同时向外扩展,当左右不相同时停止扩展,记录最长回文串长度及起始位置。

java 复制代码
    public String longestPalindrome(String str) {
        if (Objects.isNull(str) || str.isEmpty()) {
            return "";
        }
        int maxStart = 0;
        int maxLength = 1;
        for (int i = 0; i < str.length(); i++) {
            for (int k = 0; k < 2; ++k) {
                int leftIndex = i - k; // k = 0表示偶数长度,k = 1表示奇数长度
                int rightIndex = i + 1;
                while (leftIndex >= 0
                        && rightIndex < str.length()
                        && str.charAt(leftIndex) == str.charAt(rightIndex)) {
                    leftIndex--;
                    rightIndex++;
                }
                if (maxLength < rightIndex - leftIndex - 1) { // 当前length = (rightIndex - 1) - (leftIndex + 1) + 1
                    maxLength = rightIndex - leftIndex - 1;
                    maxStart = leftIndex + 1;
                }
            }
        }

        return str.substring(maxStart, maxStart + maxLength);
    }     

3.动态规划

4.Manacher(马拉车算法)

相关推荐
炽烈小老头几秒前
【每天学习一点算法2025/12/16】二叉树的最大深度
学习·算法
中國龍在廣州8 分钟前
“太空数据中心”成AI必争之地?
人工智能·深度学习·算法·机器学习·机器人
做怪小疯子9 分钟前
LeetCode 热题 100——图论——岛屿数量&腐烂的橘子&课程表
算法·leetcode·图论
dyxal13 分钟前
决策树:让机器像人类一样做选择的“思维导图”
算法·决策树·机器学习
LYFlied17 分钟前
【每日算法】LeetCode148. 排序链表
前端·数据结构·算法·leetcode·链表
长安er18 分钟前
LeetCode198打家劫舍:从回溯到动态规划的优化历程
算法·leetcode·动态规划·回溯·打家劫舍
代码游侠23 分钟前
学习笔记——线程
linux·运维·开发语言·笔记·学习·算法
又是忙碌的一天31 分钟前
八大排序之:冒泡排序、快速排序和堆排序
数据结构·算法·排序算法
scx2013100439 分钟前
20251210 DP小测总结
c++·动态规划
一直都在5721 小时前
数据结构入门:哈希表和树结构
数据结构·算法·散列表