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

两道必掌握的动态规划面试题:最长回文子串 最长公共子序列

目录一、最长回文子串Longest Palindromic Substring题目描述1. 暴力解法时间复杂度 O (n³)2. 中心扩展法时间复杂度 O (n²)空间 O (1)核心思路Java 代码实现3. 动态规划解法时间复杂度 O (n²)空间 O (n²)DP 定义状态转移方程Java 代码实现二、最长公共子序列Longest Common Subsequence, LCS题目描述1. 动态规划解法时间复杂度 O (mn)空间 O (mn)DP 定义状态转移方程Java 代码实现2. 空间优化时间复杂度 O (mn)空间 O (min (m,n))三、面试核心考点对比四、写在最后在算法面试中动态规划DP是当之无愧的高频考点。其中最长回文子串和最长公共子序列更是出现频率极高的两道经典题目。它们不仅是理解动态规划思想的绝佳案例也常常作为更复杂 DP 问题的基础模块。今天我们就来把这两道题彻底吃透。一、最长回文子串Longest Palindromic Substring题目描述给定一个字符串s找到s中最长的回文子串。回文串正读和反读都相同的字符串。示例输入babad→ 输出bab或aba输入cbbd→ 输出bb1. 暴力解法时间复杂度 O (n³)最容易想到的思路是枚举所有子串判断是否为回文串记录最长的那个。子串数量O (n²)判断回文O (n)总复杂度O (n³)字符串稍长就会超时不推荐。2. 中心扩展法时间复杂度 O (n²)空间 O (1)回文串有一个核心特征它可以由一个中心向两边扩展得到。奇数长度中心是一个字符如aba中心是b偶数长度中心是两个字符之间如abba中心在两个b之间核心思路遍历每个可能的中心向左右扩展直到不再满足回文条件记录过程中最长的回文子串。Java 代码实现java运行public String longestPalindrome(String s) { if (s null || s.length() 1) return ; int start 0, end 0; for (int i 0; i s.length(); i) { // 奇数长度 int len1 expandAroundCenter(s, i, i); // 偶数长度 int len2 expandAroundCenter(s, i, i 1); int len Math.max(len1, len2); if (len end - start) { start i - (len - 1) / 2; end i len / 2; } } return s.substring(start, end 1); } private int expandAroundCenter(String s, int left, int right) { while (left 0 right s.length() s.charAt(left) s.charAt(right)) { left--; right; } // 返回回文串长度 return right - left - 1; }3. 动态规划解法时间复杂度 O (n²)空间 O (n²)DP 定义定义dp[i][j]表示s[i..j]是否为回文子串。状态转移方程当i j时单个字符dp[i][j] true当j i 1时两个字符dp[i][j] (s[i] s[j])当j i 1时dp[i][j] (s[i] s[j] dp[i1][j-1])Java 代码实现java运行public String longestPalindrome(String s) { int n s.length(); if (n 2) return s; boolean[][] dp new boolean[n][n]; int maxLen 1, start 0; // 单个字符都是回文 for (int i 0; i n; i) dp[i][i] true; // 枚举子串长度 for (int len 2; len n; len) { for (int i 0; i n - len; i) { int j i len - 1; if (s.charAt(i) ! s.charAt(j)) { dp[i][j] false; } else { if (j - i 3) { dp[i][j] true; } else { dp[i][j] dp[i1][j-1]; } } if (dp[i][j] len maxLen) { maxLen len; start i; } } } return s.substring(start, start maxLen); }二、最长公共子序列Longest Common Subsequence, LCS题目描述给定两个字符串text1和text2返回这两个字符串的最长公共子序列的长度。如果不存在公共子序列返回 0。子序列不要求连续但相对顺序必须保持一致。示例输入text1 abcde, text2 ace→ 输出3ace输入text1 abc, text2 def→ 输出01. 动态规划解法时间复杂度 O (mn)空间 O (mn)这是一道非常经典的二维 DP 问题也是很多字符串 DP 问题的模板。DP 定义定义dp[i][j]表示text1[0..i-1]和text2[0..j-1]的最长公共子序列长度。用i-1和j-1是为了方便处理边界情况状态转移方程如果text1[i-1] text2[j-1]dp[i][j] dp[i-1][j-1] 1如果text1[i-1] ! text2[j-1]dp[i][j] Math.max(dp[i-1][j], dp[i][j-1])Java 代码实现java运行public int longestCommonSubsequence(String text1, String text2) { int m text1.length(), n text2.length(); int[][] dp new int[m 1][n 1]; for (int i 1; i m; i) { for (int j 1; j n; j) { if (text1.charAt(i - 1) text2.charAt(j - 1)) { dp[i][j] dp[i - 1][j - 1] 1; } else { dp[i][j] Math.max(dp[i - 1][j], dp[i][j - 1]); } } } return dp[m][n]; }2. 空间优化时间复杂度 O (mn)空间 O (min (m,n))因为每次计算dp[i][j]只需要上一行和当前行的值我们可以用一维数组来优化空间。java运行public int longestCommonSubsequence(String text1, String text2) { // 保证 text2 是较短的字符串 if (text1.length() text2.length()) { return longestCommonSubsequence(text2, text1); } int m text1.length(), n text2.length(); int[] dp new int[n 1]; for (int i 1; i m; i) { int prev 0; // 保存 dp[i-1][j-1] for (int j 1; j n; j) { int temp dp[j]; if (text1.charAt(i - 1) text2.charAt(j - 1)) { dp[j] prev 1; } else { dp[j] Math.max(dp[j], dp[j - 1]); } prev temp; } } return dp[n]; }三、面试核心考点对比表格题目核心思想推荐解法关键区别最长回文子串利用回文串的对称性中心扩展法处理 “连续” 的子串关注对称性最长公共子序列利用 DP 记录子问题二维动态规划处理 “非连续” 的子序列关注公共性四、写在最后这两道题是算法面试的 “敲门砖”掌握它们不仅是为了应付面试更是为了建立起动态规划的解题思维。遇到字符串问题先想想能不能用 DP 建模遇到回文问题优先考虑中心扩展法遇到两个字符串的比较问题优先考虑二维 DP。

相关文章:

两道必掌握的动态规划面试题:最长回文子串 最长公共子序列

目录 一、最长回文子串(Longest Palindromic Substring) 题目描述 1. 暴力解法(时间复杂度 O (n)) 2. 中心扩展法(时间复杂度 O (n),空间 O (1)) 核心思路 Java 代码实现 3. 动态规划解法…...

Qwen2-VL-2B-Instruct应用场景:媒体库智能打标与跨模态内容归档系统

Qwen2-VL-2B-Instruct应用场景:媒体库智能打标与跨模态内容归档系统 1. 项目背景与价值 现代企业和个人创作者都面临着一个共同的难题:随着图片、视频、文档等多媒体内容的爆炸式增长,如何高效地管理和检索这些资源?传统的文件名…...

如何防止SQL触发器导致事务超时_拆分逻辑为异步队列处理

触发器中禁止耗时操作,应改用异步方案:MySQL用消息表轮询,PostgreSQL优先用LISTEN/NOTIFY;需保障幂等、唯一ID、上下文完整及超时重试。触发器里直接调用耗时操作必然拖垮事务SQL 触发器运行在主事务上下文中,INSERT/U…...

PHP源码运行是否受硬盘转速影响_7200转vs5400转对比【指南】

PHP执行时间基本不受硬盘转速影响,但文件首次加载、opcode编译、同步I/O阻塞等环节会受5400转硬盘拖累;启用OPcache、禁用时间戳验证、缓存配置模板、优化自动加载可有效规避磁盘延迟。PHP脚本执行时间基本不受硬盘转速影响只要代码已加载进内存、OPcach…...

私有化部署企业级融媒体平台EasyDSS三大核心技术解析,筑牢校园数字化建设根基

校园数字化建设的稳步推进,离不开核心技术的支撑。EasyDSS之所以能在校园场景中实现广泛应用,核心在于其高清直播、极速点播、视频会议三大领域的技术深耕,通过持续的技术优化与创新,打造出适配校园场景的高品质数字化服务&#x…...

Redis 慢查询日志分析与性能调优

Redis作为一款高性能内存数据库,其响应速度直接影响业务体验。当出现性能瓶颈时,慢查询日志成为关键突破口。本文将深入分析Redis慢查询日志的实用技巧,并提供针对性性能调优方案,帮助开发者快速定位并解决潜在问题。 慢查询日志…...

Keil MDK-ARM编译报错‘A Label was found which was in no AREA’?手把手教你写对INCBIN汇编文件

Keil MDK-ARM编译报错‘A Label was found which was in no AREA’?手把手教你写对INCBIN汇编文件 在嵌入式开发中,直接访问二进制数据的需求非常普遍——可能是预计算的校验表、固件镜像或是其他工具生成的配置数据。当你在Keil MDK-ARM环境中尝试用汇编…...

5大核心优势:NVMe设备全生命周期管理工具深度解析

5大核心优势:NVMe设备全生命周期管理工具深度解析 【免费下载链接】nvme-cli NVMe management command line interface. 项目地址: https://gitcode.com/gh_mirrors/nv/nvme-cli 在当今数据中心和高性能计算环境中,NVMe存储技术凭借其超低延迟和高…...

Dify多模态Pipeline调试失败率下降82%的关键动作:OpenTelemetry埋点+自定义Trace Context注入实战

第一章:Dify多模态集成调试的挑战与现状Dify 作为低代码 AI 应用开发平台,原生支持文本生成、RAG 和 Agent 编排,但其多模态能力(如图像理解、语音转写、跨模态检索)仍需通过自定义模型服务、插件或外部 API 集成实现。…...

Dify日志审计配置总失败?92%团队忽略的时区陷阱、权限继承断层与审计缓冲区溢出问题全解析,立即修复!

第一章:Dify 2026日志审计配置失败的典型现象与根因图谱当 Dify 2026 版本启用日志审计功能后,运维人员常观察到审计日志缺失、时间戳错乱、关键操作事件未捕获等异常。这些表象背后往往指向统一的配置链路断裂:从环境变量注入、审计中间件加…...

057.YOLOv5代码调试技巧:用VSCode/PyCharm给深度学习“把脉”

最近在项目里遇到一个诡异的问题:YOLOv5训练时loss曲线看着挺正常,但验证集mAP就是上不去。模型推理时偶尔还会出现框位置漂移,像是特征图对齐出了问题。这种时候,光靠print和猜是没用的,得上调试器——就像给代码做一次深度CT扫描。 从一次真实调试经历说起 那天晚上十…...

爱毕业(aibiye)优化数学建模论文的复现流程,确保智能排版的高效与准确

还在为论文写作头痛?特别是数学建模的优秀论文复现与排版,时间紧、任务重,AI工具能帮上大忙吗?今天,我们评测10款热门AI论文写作工具,帮你精准筛选最适合的助手。 aibiye:专注于语法润色与结构…...

爱毕业(aibiye)让数学建模论文的复现更便捷,排版更符合学术规范

还在为论文写作头痛?特别是数学建模的优秀论文复现与排版,时间紧、任务重,AI工具能帮上大忙吗?今天,我们评测10款热门AI论文写作工具,帮你精准筛选最适合的助手。 aibiye:专注于语法润色与结构…...

保姆级避坑指南:Redmi AC2100刷Breed和固件时,你可能遇到的5个‘坑’及解决方法

Redmi AC2100刷机实战:5个高频翻车点与深度救援方案 当你盯着论坛里那些"一次成功"的刷机帖时,可能没想到自己会卡在某个莫名其妙的环节。作为刷过三十多台AC2100的老玩家,我见过太多人在相同的地方跌倒——Stok码突然失效、Breed界…...

CSS如何制作下拉菜单弹性展开_利用transform-origin

下拉菜单用 transform: scaleY() 展开时从顶部塌陷,是因为默认 transform-origin 为 50% 50%,需设为 top center 实现从顶向下自然展开;配合 cubic-bezier 缓动、will-change 优化及 pointer-events 控制确保跨端稳定。下拉菜单用 transform:…...

CANFD数据帧格式详解:从显性/隐性电平到64字节DLC编码,一张图看懂协议升级

CANFD协议深度解码:从电平博弈到64字节数据帧的工程智慧 在汽车电子与工业控制领域,实时可靠的数据传输如同神经系统般重要。传统CAN总线曾是这个领域的王者,但随着智能驾驶、车联网等技术的爆发式发展,500Kbps的带宽逐渐显得捉襟…...

心知天气API + ArduinoJson库实战:手把手教你为ESP8266天气时钟解析复杂JSON数据

心知天气API与ArduinoJson库深度解析:ESP8266天气时钟的JSON处理实战 在物联网开发中,数据获取与处理是核心技能之一。当我们使用ESP8266这类资源有限的微控制器时,如何高效解析复杂的JSON数据成为项目成功的关键。本文将聚焦心知天气API返回…...

别再只盯着蓝绿部署了!用Kubernetes + Istio 玩转金丝雀发布,5分钟搞定灰度流量配置

Kubernetes Istio 金丝雀发布实战:从流量分配到版本熔断 当你的微服务需要上线新功能时,直接全量发布就像在黑暗中跳跃——你永远不知道用户会迎来惊喜还是惊吓。金丝雀发布给了我们更优雅的选择:让新版本像矿洞里的金丝雀一样,先…...

NXP S32K的SIUL2模块详解:不止是GPIO,更是中断与DMA的枢纽

NXP S32K的SIUL2模块深度解析:从引脚路由到高效中断管理 在嵌入式系统开发中,GPIO管理往往被视为基础功能,但NXP S32K系列芯片中的SIUL2模块却颠覆了这一认知。作为System Integration Unit Lite2的缩写,SIUL2远不止是一个简单的G…...

如何处理宝塔面板Go项目守护进程无法常驻的问题_使用进程管理器添加执行脚本并配置重启策略

Go项目在宝塔中自动退出的根本原因是前台阻塞运行与进程管理器配置不匹配:需为supervisord设autorestarttrue、startsecs0及绝对路径;systemd则须配Typesimple、Restartalways、WorkingDirectory和Userwww。Go 项目在宝塔里启动后自动退出,sy…...

如何快速解密QQ音乐加密文件:qmcdump完全指南

如何快速解密QQ音乐加密文件:qmcdump完全指南 【免费下载链接】qmcdump 一个简单的QQ音乐解码(qmcflac/qmc0/qmc3 转 flac/mp3),仅为个人学习参考用。 项目地址: https://gitcode.com/gh_mirrors/qm/qmcdump 你是否曾经下载…...

00101

1001101...

告别延时函数!用STM32CubeMX的SPI+DMA驱动WS2812灯带,CPU占用率直降90%

STM32CubeMX高效驱动WS2812:SPIDMA方案深度解析与实战 当LED灯带遇上嵌入式系统,传统延时函数就像用算盘处理大数据——勉强能用但效率堪忧。今天我们要拆解的是一种工业级解决方案:通过STM32CubeMX配置SPIDMA驱动WS2812灯带,这个…...

海思3516a OSD水印进阶:动态更新、多区域叠加与性能优化心得

海思3516a OSD水印进阶:动态更新、多区域叠加与性能优化实战 在嵌入式视频处理领域,OSD(On-Screen Display)水印功能早已超越简单的静态文字叠加,成为智能设备中不可或缺的信息交互层。当我们面对安防摄像头需要实时更…...

实测5款AI论文写作工具:好写作AI的“思维健身房”到底强在哪?

写论文最痛苦的不是“改”,而是“开始”。选题卡壳、文献读不完、框架搭不起来、写了一半发现逻辑断了……这些问题任何一款AI都解决不了,因为你面对的根本不是一个“字写不出来”的问题,而是一个“脑子想不清楚”的问题。 最近我花了三周时…...

ESP-SR V2.0架构解密:嵌入式语音识别的性能突破与实战优化

ESP-SR V2.0架构解密:嵌入式语音识别的性能突破与实战优化 【免费下载链接】esp-sr Speech recognition 项目地址: https://gitcode.com/gh_mirrors/es/esp-sr ESP-SR是乐鑫科技专为ESP32系列芯片优化的完全离线语音识别框架,为IoT设备提供低延迟…...

Dify 2026工作流引擎升级全解析:如何用新编排能力将AI应用交付周期缩短67%?

第一章:Dify 2026工作流引擎升级全景概览Dify 2026版本对工作流引擎进行了深度重构,核心目标是提升低代码编排能力、增强异步任务可观测性,并原生支持多模态节点协同执行。本次升级不再依赖外部调度中间件,而是将轻量级事件总线与…...

飞秋Mac版:终极开源局域网通信工具完全指南

飞秋Mac版:终极开源局域网通信工具完全指南 【免费下载链接】feiq 基于qt实现的mac版飞秋,遵循飞秋协议(飞鸽扩展协议),支持多项飞秋特有功能 项目地址: https://gitcode.com/gh_mirrors/fe/feiq 飞秋Mac版是基于Qt框架开发的跨平台局…...

05华夏之光永存:黄大年茶思屋榜文解法「第10期第5题」云渲染实时性卡点:多GPU分布式任务调度双路径工程解法

华夏之光永存:黄大年茶思屋榜文解法「第10期第5题」 云渲染实时性卡点:多GPU分布式任务调度双路径工程解法 一、摘要 本题为该领域顶级技术难题,本文采用工程化可复现逻辑,提供两条标准化解题路径,全程符合工程师技术认…...

04华夏之光永存:黄大年茶思屋榜文解法「第10期第4题」 AI运筹优化核心卡点:MIP求解器自学习双路径工程解法

华夏之光永存:黄大年茶思屋榜文解法「第10期第4题」 AI运筹优化核心卡点:MIP求解器自学习双路径工程解法 一、摘要 本题为该领域顶级技术难题,本文采用工程化可复现逻辑,提供两条标准化解题路径,全程符合工程师技术认知…...