当前位置: 首页 > article >正文

从‘马拉车’到‘回文中心’:图解Manacher算法,让晦涩概念一目了然

从‘马拉车’到‘回文中心’图解Manacher算法让晦涩概念一目了然第一次接触回文串问题时大多数人会本能地想到中心扩展法——从每个字符向两侧扫描直到发现不对称的字符为止。这种方法简单直接但当处理长字符串时其O(n²)的时间复杂度往往让人望而却步。1975年计算机科学家Glenn Manacher提出了一种巧妙的线性时间算法通过利用回文串的对称性质将时间复杂度降至O(n)。这个算法后来被亲切地称为马拉车算法不仅因为其英文名谐音更因为它像一辆高效的马车能快速遍历字符串的每个角落。1. 理解回文串的核心挑战回文串的对称美在数学上令人着迷但在计算机处理时却带来了两个棘手问题奇偶性困境长度为5的ababa奇数长度和长度为4的abba偶数长度具有不同的对称中心结构重复计算传统中心扩展法对每个字符独立扩展无法利用已发现的回文串信息1.1 预处理统一奇偶情况Manacher算法的第一个精妙之处在于预处理def preprocess(s: str) - str: return # #.join(s) # print(preprocess(abba)) # 输出#a#b#b#a#这种插入特殊字符通常用#的方法实现了两个关键效果将原始字符串长度从n扩展到2n1确保总是奇数长度新字符串中每个原始字符两侧都有#统一了处理逻辑转换效果对比原始字符串转换后最长回文半径aba#a#b#a#[0,1,0,3,0,1,0]abba#a#b#b#a#[0,1,0,1,4,1,0,1,0]2. 算法核心利用对称性避免重复计算2.1 关键概念解析回文中心(C)当前已知右边界最远的回文串中心位置半径数组(r[])记录每个位置能扩展的最大回文半径最右边界(R)C r[C]即当前已知回文串能达到的最右索引提示半径r[i]表示以i为中心的回文串向左右能扩展的字符数不包括中心本身2.2 对称点优化原理当扫描到位置i时如果i在当前最右回文串范围内i R则可以找到其关于中心C的对称点i情况一i的回文完全在C的回文内 → r[i] r[i]情况二i的回文超出C的左边界 → r[i] R - i情况三i的回文刚好到达左边界 → 从R开始继续扩展def manacher(s: str) - list: T preprocess(s) n len(T) r [0] * n C R 0 for i in range(1, n-1): mirror 2 * C - i # 计算i关于C的对称点 if i R: r[i] min(R - i, r[mirror]) # 尝试扩展 while (i - 1 - r[i] 0 and i 1 r[i] n and T[i - 1 - r[i]] T[i 1 r[i]]): r[i] 1 # 更新最右边界和中心 if i r[i] R: C, R i, i r[i] return r3. 可视化执行流程以字符串abababa为例观察算法执行过程步骤当前中心C最右R处理i操作1001暴力扩展r[1]12122对称点i0r[2]03123对称点i-1暴力扩展r[3]34364对称点i2r[4]min(6-4,0)05365对称点i1r[5]min(6-5,1)16576对称点i4r[6]min(7-6,0)0关键观察点当i3时通过暴力扩展发现长回文将R推到6i4和i6都直接利用了对称信息避免重复计算i5虽然利用了对称信息但仍需少量扩展4. 复杂度分析与实际应用4.1 为什么是O(n)算法性能依赖于两个关键观察R单调递增每次扩展都使R严格增大对称点优化大部分情况直接确定r[i]无需扩展注意while循环的总次数不超过n次因为R最多增长到n4.2 典型应用场景最长回文子串直接取max(r)即为解双回文串问题预处理左右最大回文信息回文计数统计所有可能回文组合性能对比方法时间复杂度空间复杂度适用场景暴力法O(n²)O(1)短字符串动态规划O(n²)O(n²)需要所有子串信息ManacherO(n)O(n)单次查询最长回文在实际编码竞赛中Manacher算法因其高效性成为解决回文问题的首选。例如处理长度为10⁶的字符串时暴力方法可能需要数秒而Manacher能在毫秒级完成。

相关文章:

从‘马拉车’到‘回文中心’:图解Manacher算法,让晦涩概念一目了然

从‘马拉车’到‘回文中心’:图解Manacher算法,让晦涩概念一目了然 第一次接触回文串问题时,大多数人会本能地想到中心扩展法——从每个字符向两侧扫描,直到发现不对称的字符为止。这种方法简单直接,但当处理长字符串时…...

含光伏接入的14节点配网储能选址定容模型优化——基于改进粒子群算法的程序实现

含光伏的储能选址定容模型 14节点 程序采用改进粒子群算法,对分析14节点配网系统中的储能选址定容方案,并得到储能的出力情况,有相关参考资料 这段程序是一个粒子群算法(Particle Swarm Optimization, PSO)的实现&…...

从David Marr的视觉计算理论,聊聊为什么你的CV模型总感觉“差点意思”

从David Marr的视觉计算理论看现代CV模型的认知鸿沟 当你盯着监控画面里误将树影识别为行人的AI系统,或是看着医疗影像分析模型对轻微噪点就产生误诊时,是否思考过:为什么这些在测试集上表现优异的模型,面对真实世界却总显得"…...

避开STM32硬件I2C的坑:我是如何用模拟SMBus稳定驱动BQ4050的

避开STM32硬件I2C的坑:我是如何用模拟SMBus稳定驱动BQ4050的 在嵌入式开发中,与BQ4050这类智能电池管理芯片通信是许多项目的关键环节。作为一名长期与STM32打交道的工程师,我曾天真地认为硬件I2C外设是连接BQ4050的最佳选择——直到现实给了…...

从一根烧掉的射频功放管说起:聊聊阻抗不匹配的‘血泪史’与Smith圆图避坑指南

从一根烧掉的射频功放管说起:聊聊阻抗不匹配的‘血泪史’与Smith圆图避坑指南 那是一个周五的深夜,实验室里弥漫着焦糊味。当我盯着示波器上消失的信号波形,拆开散热器看到发黑的功放管时,才真正理解教科书上那句"阻抗匹配是…...

DamaiHelper终极指南:如何用Python+Selenium实现大麦网抢票自动化300%效率提升

DamaiHelper终极指南:如何用PythonSelenium实现大麦网抢票自动化300%效率提升 【免费下载链接】DamaiHelper 大麦网演唱会演出抢票脚本。 项目地址: https://gitcode.com/gh_mirrors/dama/DamaiHelper 在热门演唱会、话剧和体育赛事门票开售的瞬间&#xff0…...

GPTeam多智能体框架:构建AI协作团队的技术实践

1. 项目概述:当AI学会“组队”与“协作”最近在AI应用开发圈里,一个名为“GPTeam”的开源项目引起了我的注意。它不是一个单一的AI模型,而是一个模拟人类团队协作的“多智能体”框架。简单来说,GPTeam让你可以创建多个拥有不同角色…...

从libgtk-3.so.0到libasound.so.2:一站式解决Playwright浏览器自动化依赖缺失难题

1. 当Playwright遇上缺失的依赖库:一个真实案例 上周我在阿里云ECS上部署一个爬虫项目时,遇到了这样的错误提示: Host system is missing dependencies to run browsers. Missing libraries: libgtk-3.so.0 libasound.so.2 libXtst.so.6这种情…...

基于Claude大语言模型构建智能用户评论分析系统:架构、Prompt工程与实战

1. 项目概述:一个基于Claude的智能评论分析引擎最近在折腾一个挺有意思的项目,名字叫“claude-reviews-claude”。乍一看这名字有点绕,像是套娃,但它的核心思路其实非常清晰:利用Claude大语言模型的能力,去…...

QtCreator+CMake+Ninja:跨平台C++开发环境高效搭建指南

1. 为什么选择QtCreatorCMakeNinja组合? 如果你正在开发跨平台的C应用程序,那么QtCreatorCMakeNinja这个组合绝对值得一试。作为一个长期使用这套工具链的开发者,我发现它完美解决了传统构建方式中的几个痛点:编译速度慢、配置复杂…...

2026 论文写作软件红黑榜:AI 论文写作软件怎么选?用数据说话!

2026 年论文写作工具红榜榜单正式发布,掌桥科研 AI 写作、ThouPen、豆包因深度贴合国内学术标准,位列红榜前列。黑榜则提醒大家远离劣质免费工具、无真实文献引用平台以及过度主打全文生成的 AI 软件。挑选时可参考三大核心维度:需求契合度、…...

Android 刷机

Android 刷机TWRP 使用adb sideload 线刷ROM的方法刷入TWRP异常处理:线刷流程:fastboot 刷入官方包刷机流程问题安装完成后无法获取root权限安装magisk并root网络问题wifi 无法使用:安装charler 证书代理证书问题关于权限问题的解决抓包异常排…...

C++26反射元编程落地三阶段路线图:从std::is_reflectable判断→编译期结构体遍历→运行时反射缓存,附可直接集成的CMake模块

更多请点击: https://intelliparadigm.com 第一章:C26反射特性在元编程中的应用对比评测报告 C26 正式引入基于 std::reflect 的静态反射核心设施,标志着元编程范式从模板元编程(TMP)和 constexpr 编程迈向声明式、可…...

【困难】邮局选址问题-Java:解法二

分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请轻击人工智能教程大家好!欢迎来到我的网站! 人工智能被认为是一种拯救世界、终结世界的技术。毋庸置疑&#x…...

3步搞定Unity游戏资源修改:UABEA零代码模组制作完全指南

3步搞定Unity游戏资源修改:UABEA零代码模组制作完全指南 【免费下载链接】UABEA c# uabe for newer versions of unity 项目地址: https://gitcode.com/gh_mirrors/ua/UABEA 你是否曾梦想过亲手改造喜欢的游戏,却因复杂的编程门槛望而却步&#x…...

Zotero重复文献清理深度解析:3步实现高效文献库去重管理

Zotero重复文献清理深度解析:3步实现高效文献库去重管理 【免费下载链接】ZoteroDuplicatesMerger A zotero plugin to automatically merge duplicate items 项目地址: https://gitcode.com/gh_mirrors/zo/ZoteroDuplicatesMerger 你是否曾因文献库中大量重…...

探索未来云计算的航标:Crane如何简化容器编排管理

探索未来云计算的航标:Crane如何简化容器编排管理 【免费下载链接】crane Yet another control plane based on docker built-in swarmkit 项目地址: https://gitcode.com/gh_mirrors/crane/crane 在当今快速发展的云计算领域,容器编排已成为构建…...

如何快速上手InstagramApiSharp:.NET平台的完整私人Instagram API指南

如何快速上手InstagramApiSharp:.NET平台的完整私人Instagram API指南 【免费下载链接】InstagramApiSharp A complete Private Instagram API for .NET (C#, VB.NET). 项目地址: https://gitcode.com/gh_mirrors/in/InstagramApiSharp InstagramApiSharp是一…...

计算机毕业设计:Python股票交易可视化管理系统 Django框架 requests爬虫 数据分析 可视化 大数据 大模型(建议收藏)✅

博主介绍:✌全网粉丝10W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业项目实战6年之久,选择我们就是选择放心、选择安心毕业✌ > 🍅想要获取完整文章或者源码,或者代做,拉到文章底部即可与…...

5分钟搞定!用Moonlight TV在大屏电视上畅玩PC游戏 [特殊字符]

5分钟搞定!用Moonlight TV在大屏电视上畅玩PC游戏 🎮 【免费下载链接】moonlight-tv Lightweight NVIDIA GameStream Client, for LG webOS TV and embedded devices like Raspberry Pi 项目地址: https://gitcode.com/gh_mirrors/mo/moonlight-tv …...

如何快速获取百度网盘直链:3步终极解决方案告别限速困扰

如何快速获取百度网盘直链:3步终极解决方案告别限速困扰 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 你是否曾因百度网盘的下载速度限制而倍感焦虑?…...

终极显卡驱动清理工具Display Driver Uninstaller完整使用指南

终极显卡驱动清理工具Display Driver Uninstaller完整使用指南 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/display-drivers-uninstaller …...

Tau:革命性Git-Native CDN PaaS平台,构建自主云计算网络的终极指南

Tau:革命性Git-Native CDN PaaS平台,构建自主云计算网络的终极指南 【免费下载链接】tau Fullstack Workspace for Humans & Machines 项目地址: https://gitcode.com/gh_mirrors/ta/tau Tau(全称Taubyte)是一个革新性…...

【异常】QClaw客户端安装失败(OpenClaw资源解压出错)问题排查与修复指南: 安装失败:OpenClaw 资源解压出错。 请重新安装或联系支持。

QClaw客户端安装失败(OpenClaw资源解压出错)问题排查与修复指南 本文针对QClaw客户端安装/更新过程中出现的“OpenClaw资源解压出错”报错,完整梳理报错信息、根因说明,并提供分阶段、可落地的标准化修复方案,保障客户端正常部署。 一、报错内容 触发场景:QClaw客户端执…...

Ash Framework与Phoenix集成:构建完整Web应用的终极指南

Ash Framework与Phoenix集成:构建完整Web应用的终极指南 【免费下载链接】ash A declarative, extensible framework for building Elixir applications. 项目地址: https://gitcode.com/gh_mirrors/ash/ash Ash Framework是一个声明式、可扩展的Elixir应用框…...

告别回调地狱:用Rust async/await优雅封装UCX高性能通信库

用Rust异步编程重构UCX:从回调地狱到协程优雅 在当今高性能计算和分布式系统领域,UCX(Unified Communication X)作为统一通信抽象层的重要性与日俱增。然而,其基于C语言的回调式异步编程模型,让不少开发者望…...

告别存储焦虑:巧用Alist与RaiDrive,将百度网盘无缝变成本地硬盘

1. 为什么你的电脑总是不够用? 每次打开电脑,那个刺眼的红色存储空间警告就像个定时炸弹一样跳出来。你可能已经删掉了无数个"暂时用不到"的文件,清空了回收站,甚至卸载了几个很久不用的软件,但没过多久&…...

别再让舵机乱抖了!STM32F103C8T6驱动MG90S的完整配置流程(附代码)

从零构建稳定舵机控制系统:STM32F103C8T6与MG90S深度实战指南 第一次尝试用STM32驱动MG90S舵机时,我盯着那个抽搐的金属齿轮发了半小时呆——它时而疯狂抖动,时而完全静止,就像在嘲笑我的代码。这不是个例,几乎所有嵌入…...

算法正确性证明终极指南:数学归纳法与循环不变式实战应用

算法正确性证明终极指南:数学归纳法与循环不变式实战应用 【免费下载链接】CLRS :notebook:Solutions to Introduction to Algorithms 项目地址: https://gitcode.com/gh_mirrors/cl/CLRS 算法正确性证明是计算机科学中的核心技能,它确保我们设计…...

3步搞定显卡驱动残留:Display Driver Uninstaller终极清理指南

3步搞定显卡驱动残留:Display Driver Uninstaller终极清理指南 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/display-drivers-unin…...