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

二刷算法训练营Day53 | 动态规划(14/17)

目录

详细布置:

1. 392. 判断子序列

2. 115. 不同的子序列


详细布置:

1. 392. 判断子序列

给定字符串 s 和 t ,判断 s 是否为 t 的子序列。

字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace""abcde"的一个子序列,而"aec"不是)。

进阶:

如果有大量输入的 S,称作 S1, S2, ... , Sk 其中 k >= 10亿,你需要依次检查它们是否为 T 的子序列。在这种情况下,你会怎样改变代码?

致谢:

特别感谢 @pbrother 添加此问题并且创建所有测试用例。

(这道题也可以用双指针的思路来实现,时间复杂度也是O(n))

这道题应该算是编辑距离的入门题目,因为从题意中我们也可以发现,只需要计算删除的情况,不用考虑增加和替换的情况。

所以掌握本题的动态规划解法是对后面要讲解的编辑距离的题目打下基础


2. 115. 不同的子序列

给你两个字符串 s 和 t ,统计并返回在 s 的 子序列 中 t 出现的个数,结果需要对 109 + 7 取模。

这道题目相对于72. 编辑距离,简单了不少,因为本题相当于只有删除操作,不用考虑替换增加之类的。

但相对于刚讲过的动态规划:392.判断子序列 (opens new window)就有难度了,这道题目双指针法可就做不了了

class Solution:def numDistinct(self, s: str, t: str) -> int:dp = [[0] * (len(t)+1) for _ in range(len(s)+1)]for i in range(len(s)):dp[i][0] = 1for j in range(1, len(t)):dp[0][j] = 0for i in range(1, len(s)+1):for j in range(1, len(t)+1):if s[i-1] == t[j-1]:dp[i][j] = dp[i-1][j-1] + dp[i-1][j]else:dp[i][j] = dp[i-1][j]return dp[-1][-1]

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

相关文章:

  • 将缓冲文件写到磁盘中的命令sync
  • 灵活视图变换器:为扩散模型设计的革新图像生成架构
  • [终端安全]-1 总体介绍
  • Mysql5.7并发插入死锁问题
  • 网络“ping不通”,如何排查和解决呢?
  • 日常学习--20240706
  • 入门PHP就来我这(高级)12 ~ 获取数据
  • AIGC专栏12——EasyAnimateV3发布详解 支持图文生视频 最大支持960x960x144帧视频生成
  • 【python】python猫眼电影数据抓取分析可视化(源码+数据集+论文)【独一无二】
  • Android 四大组件
  • 【Python】已解决:ModuleNotFoundError: No module named ‘nltk’
  • 【Docker系列】Docker 命令行输出格式化指南
  • 使用Netty构建高性能的网络应用
  • C++11新特性【下】{lambda表达式、可变模板参数、包装器}
  • SpringBoot使用手册
  • HTML CSS 基础复习笔记 - 列表使用
  • 017-GeoGebra基础篇-微积分函数求解圆弧面积问题
  • Element中的选择器组件Select (一级选择组件el-select)
  • 数值分析笔记(五)线性方程组解法
  • IDEA中Maven的配置
  • 成人高考本科何时报名-深职训学校帮您规划学习之路
  • C++ STL 协程(Coroutines)
  • 虚拟机下基于海思移植QT(一)——虚拟机下安装QT
  • 计算机网络部分知识点整理
  • 【Qt】Qt概述
  • 读书笔记-《魔鬼经济学》
  • 2024.7.7总结
  • uniapp做小程序内打开地图展示位置信息
  • leetcode 283.移动零
  • Unity | Shader基础知识(第十七集:学习Stencil并做出透视效果)