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

最长回文字串

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

相关推荐
Zach_yuan15 小时前
算法1111
算法
不穿格子的程序员16 小时前
从零开始刷算法——二分-搜索旋转排序数组
数据结构·算法
做怪小疯子16 小时前
LeetCode 热题 100——哈希——最长连续序列
算法·leetcode·哈希算法
做怪小疯子17 小时前
LeetCode 热题 100——双指针——三数之和
算法·leetcode·职场和发展
高山上有一只小老虎17 小时前
等差数列前n项的和
java·算法
sin_hielo17 小时前
leetcode 2536
数据结构·算法·leetcode
flashlight_hi17 小时前
LeetCode 分类刷题:203. 移除链表元素
算法·leetcode·链表
py有趣17 小时前
LeetCode算法学习之数组中的第K个最大元素
学习·算法·leetcode
吗~喽17 小时前
【LeetCode】将 x 减到 0 的最小操作数
算法·leetcode
what_201817 小时前
list集合使用
数据结构·算法·list