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

算法刷题Day28:BM66 最长公共子串

题目链接,点击跳转

题目描述:

在这里插入图片描述

解题思路:

方法一:暴力枚举

  1. 遍历str1的每个字符x,并在str2中寻找以相同元素x为起始的最长字符串。
  2. 记录最长的公共子串及其长度。

代码实现:

def LCS(self, str1: str, str2: str) -> str:
len1 = len(str1)
len2 = len(str2)
max_start = 0
max_end = 0
max_length = 0
for i in range(len1):
for j in range(len2):
if str2[j] == str1[i]:
pos1 = i
pos2 = j
length = 0
while pos1 < len1 and pos2 < len2 and str1[pos1] == str2[pos2]:
length += 1
pos1 += 1
pos2 += 1
if length > max_length:
max_length = length
max_start = j
max_end = pos2
return str2[max_start:max_end]

分析:
时间复杂度:O(n \* m \* min(n, m)),其中 nm 分别是两个字符串的长度。
空间复杂度:O(1)
缺点:时间复杂度过高,在字符串较长时会超时。

方法二:动态规划

  1. 使用一个二维数组来记录子串长度
  2. 状态转移方程
    如果str1[i-1] == str2[j-1],则dp[i][j] = dp[i-1][j-1] +1
    如果str1[i-1] != str2[j-1],则dp[i][j] = 0

代码实现:

def LCS(self, str1: str, str2: str) -> str:
len1 = len(str1)
len2 = len(str2)
max_end = 0
max_length = 0
dp = [[0 for _ in range(len2 + 1)] for _ in range(len1 + 1)]
for i in range(1, len1 + 1):
for j in range(1, len2 + 1):
if str1[i - 1] == str2[j - 1]:
dp[i][j] = dp[i - 1][j - 1] + 1
if dp[i][j] > max_length:
max_end = j
max_length = dp[i][j]
else:
dp[i][j] = 0
return str2[max_end - max_length:max_end]

时间复杂度:O(n \* m),其中 nm 分别是两个字符串的长度。
空间复杂度:O(n \* m)
缺点:python版本会超时

方法三:滑动窗口

1.遍历较长的字符串,判断窗口内的字符,是否存在于在另一个字符串中。

代码实现

def LCS(self, str1: str, str2: str) -> str:
if len(str1) < len(str2):
str1, str2 = str2, str1
res = ""
max_len = 0
for i in range(len(str1)):
if str1[i - max_len:i + 1] in str2:
res = str1[i - max_len:i + 1]
max_len += 1
return res

时间复杂度:O(n\*k\*m)。其中 n 是较长字符串的长度。k 是切片长度,最多为 n。使用 in 判断是否存在于 str2 中,其时间复杂度为 O(m),其中 m str2 的长度。

http://www.lryc.cn/news/527758.html

相关文章:

  • 论文阅读笔记:MambaOut: Do We Really Need Mamba for Vision?
  • HarmonyOS:ForEach:循环渲染
  • Python3 【函数】项目实战:5 个新颖的学习案例
  • XSS 漏洞全面解析:原理、危害与防范
  • 从 GShard 到 DeepSeek-V3:回顾 MoE 大模型负载均衡策略演进
  • 【回溯+剪枝】回溯算法的概念 全排列问题
  • Flutter解决macbook M芯片Android Studio中不显示IOS真机的问题
  • 自签证书的dockerfile中from命令无法拉取镜像而docker的pull命令能拉取镜像
  • 【MySQL】--- 复合查询 内外连接
  • QT TLS initialization failed
  • 系统学英语 — 句法 — 复合句
  • 指针的介绍2前
  • 16.Word:石油化工设备技术❗【28】
  • Python-基础环境(01) 虚拟环境,Python 基础环境之虚拟环境,一篇文章助你完全搞懂!
  • Dest1ny漏洞库:用友 U8-CRM 系统 ajaxgetborrowdata.php 存在 SQL 注入漏洞
  • java.sql.Date 弃用分析与替代方案
  • HarmonyOS:状态管理最佳实践
  • 如何提高新产品研发效率
  • MongoDB平替数据库对比
  • JavaScript系列(46)-- WebGL图形编程详解
  • YOLO目标检测4
  • 十三先天记
  • 【论文阅读笔记】“万字”关于深度学习的图像和视频阴影检测、去除和生成的综述笔记 | 2024.9.3
  • Android AOP:aspectjx
  • 前端【11】HTML+CSS+jQUery实战项目--实现一个简单的todolist
  • 2025课题推荐——USBL与DVL数据融合的实时定位系统
  • 滑动窗口详解:解决无重复字符的最长子串问题
  • 第05章 11 动量剖面可视化代码一则
  • MySQL的复制
  • Cpp::IO流(37)