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

最长回文字串

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(马拉车算法)

相关推荐
SWAGGY..2 分钟前
数据结构学习篇(8)---二叉树
数据结构·学习·算法
星轨初途4 分钟前
牛客小白月赛126
开发语言·c++·经验分享·笔记·算法
leoufung9 分钟前
动态规划DP 自我提问模板
算法·动态规划
爱编程的小吴16 分钟前
【力扣练习题】热题100道【哈希】560. 和为 K 的子数组
算法·leetcode·哈希算法
Swift社区21 分钟前
LeetCode 463 - 岛屿的周长
算法·leetcode·职场和发展
皮卡蛋炒饭.23 分钟前
宽搜bfs与深搜dfs
算法·宽度优先
Coder_Boy_27 分钟前
基于SpringAI的智能AIOps项目:部署相关容器化部署管理技术图解版
人工智能·spring boot·算法·贪心算法·aiops
王哈哈^_^29 分钟前
【完整源码+数据集】道路拥塞数据集,yolo道路拥塞检测数据集 8921 张,交通拥堵识别数据集,路口拥塞识别系统实战教程
深度学习·算法·yolo·目标检测·计算机视觉·分类·毕业设计
leoufung1 小时前
LeetCode 64. Minimum Path Sum 动态规划详解
算法·leetcode·动态规划
一起养小猫1 小时前
LeetCode100天Day7-移动零与搜索插入位置
数据结构·算法·leetcode·指针