LeetCode题练习与总结:不同的子序列--115

一、题目描述

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

示例 1:

输入:s = "rabbbit", t = "rabbit"
输出3
解释:
如下所示, 有 3 种可以从 s 中得到 "rabbit" 的方案rabbbit
rabbbit
rabbbit

示例 2:

输入:s = "babgbag", t = "bag"
输出5
解释:
如下所示, 有 5 种可以从 s 中得到 "bag" 的方案babgbag
babgbag
babgbag
babgbag
babgbag

提示:

  • 1 <= s.length, t.length <= 1000
  • s 和 t 由英文字母组成

二、解题思路

这个问题可以通过动态规划来解决。我们可以创建一个二维数组 dp,其中 dp[i][j] 表示在 s 的前 i 个字符中,包含 t 的前 j 个字符的子序列的数量。我们需要填充这个数组来找到最终的答案。

对于动态规划数组 dp 的填充,我们有以下几种情况:

1. 如果 s 的第 i 个字符等于 t 的第 j 个字符,那么 dp[i][j] 可以由两部分组成:

  • 不使用 s 的第 i 个字符,只考虑前 i-1 个字符和 t 的前 j 个字符的匹配情况,即 dp[i-1][j]
  • 使用 s 的第 i 个字符,考虑 s 的前 i-1 个字符和 t 的前 j-1 个字符的匹配情况,即 dp[i-1][j-1]

2. 如果 s 的第 i 个字符不等于 t 的第 j 个字符,那么我们只能忽略 s 的第 i 个字符,dp[i][j] 应该等于 dp[i-1][j]

初始化时,dp[0][0] 应该为 1,因为两个空字符串的匹配情况只有一种,即不使用任何字符。其他的 dp[i][0] 应该为 1,因为 t 为空字符串时,匹配情况只有一种,即忽略所有 s 的字符。

三、具体代码

class Solution {public int numDistinct(String s, String t) {int MOD = 1000000007;int m = s.length();int n = t.length();int[][] dp = new int[m + 1][n + 1];// 初始化for (int i = 0; i <= m; i++) {dp[i][0] = 1;}for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {if (s.charAt(i - 1) == t.charAt(j - 1)) {dp[i][j] = (dp[i - 1][j] + dp[i - 1][j - 1]) % MOD;} else {dp[i][j] = dp[i - 1][j];}}}return dp[m][n];}
}

四、时间复杂度和空间复杂度

1. 时间复杂度
  • 我们定义了两个循环,一个遍历字符串 s 的每个字符,另一个遍历字符串 t 的每个字符。
  • 外层循环遍历 s 的长度 m,内层循环遍历 t 的长度 n
  • 在循环的每一次迭代中,我们执行了常数时间的操作,包括字符比较和模运算。
  • 因此,时间复杂度是 O(m * n),其中 m 是字符串 s 的长度,n 是字符串 t 的长度。
2. 空间复杂度
  • 我们定义了一个二维数组 dp,其大小为 (m + 1) x (n + 1),其中 m 和 n 分别是字符串 s 和 t 的长度。
  • 这个数组用于存储每个子问题的解,即 s 的前 i 个字符中包含 t 的前 j 个字符的子序列的数量。
  • 因此,空间复杂度是 O(m * n),这是因为我们需要存储所有子问题的解。

五、总结知识点

  1. 动态规划:这是一种通过将问题分解为更小的子问题来解决复杂问题的方法,通常用于优化问题。在本题中,我们使用动态规划来计算字符串 s 中包含字符串 t 的子序列的数量。

  2. 二维数组:代码中使用了一个二维数组 dp 来存储动态规划的状态。二维数组是一种常用的数据结构,用于存储具有两个维度的数据。

  3. 字符串操作:代码中使用了 charAt 方法来获取字符串中特定位置的字符,这是字符串操作的基本技巧。

  4. 模运算:由于结果需要对一个大数 10^9 + 7 取模,代码中使用了模运算来避免整数溢出,并保持结果在一个合理的范围内。

  5. 边界条件处理:在动态规划的初始化阶段,我们将 dp[i][0] 设置为 1,这是因为一个空字符串总是另一个字符串的子序列,且只有一种方式可以实现。

  6. 循环结构:代码中使用了两个嵌套的循环来遍历字符串 s 和 t 的所有字符,这是实现动态规划的典型结构。

  7. 递推关系:代码中建立了动态规划的递推关系,即如果当前字符匹配,则新的状态值是上方和左上方的值之和;如果不匹配,则新的状态值等于上方的值。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/846715.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OJ1230进制的转换

答案&#xff1a; #include <bits/stdc.h> using namespace std; using lllong long; const int N10; int a[10]; char ch[]{0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F}; void solve() {int n,m;cin>>n>>m;string str;cin>>str;for(int i0;i<str.size();i)…

字符串操作java

题目&#xff1a; 描述 给定长度为n的只有小写字母的字符串s&#xff0c;进行m次操作&#xff0c;每次将[l,r]范围内所有c1字符改成c2&#xff0c;输出操作完的字符串 输入描述&#xff1a; 第一行两个数n,m 第二行一个字符串s 之后m行&#xff0c;每行两个数l 、r两个字符…

Android 系统APP提高CPU优先级,抢占不到CPU

系统APP提高CPU优先级,抢占不到CPU 1.在Android系统中,每个进程都有一个优先级,系统会根据进程的优先级来分配CPU资源。有时候android设备开机的时候负载过高,优先级较低抢占不到cpu,我们需要提高某个进程的优先级,以确保该进程能够顺利执行。 2.开发一个后台任务,需要在…

debian 将pdf 转换为jpg图片

打开终端并执行以下命令来安装这些工具&#xff1a; sudo apt-get update sudo apt-get install imagemagick ghostscript安装完成后&#xff0c;您可以使用convert命令转换PDF到JPEG&#xff1a; convert -density 300 input.pdf[0] output.jpg这里的-density 300参数是设置…

【STL】优先级队列用法介绍及其实现

目录 前言 用法介绍 模拟实现 仿函数 迭代器区间构造 插入 删除 队顶 判空 大小 完整代码 前言 优先级队列&#xff08;priority_queue&#xff09;是一种特殊的队列数据结构&#xff0c;其中每个元素都有一个“优先级”。优先级最高的元素最先出队&#xff0c;而优…

内网域中NTLM中继那些事儿

0x01 初识NTLM协议 基本概念&#xff1a;NTLM(NT LAN Manager)认证是一种早期的Windows网络身份认证协议。它在Windows系统中用于验证用户的身份&#xff0c;并提供对网络资源的访问控制&#xff0c;它是一种基于Challenge/Response的认证机制。 认证流程 NTLM协议Challenge…

Python代码关系图生成,帮助快速熟悉一个项目

一、静态代码关系图 工具1、pyreverse pyreverse 是一个由 Logilab 开发的 Python 工具&#xff0c;它能够自动生成 UML (统一建模语言) 类图&#xff0c;这些类图基于 Python 源代码。pyreverse 可以分析 Python 代码&#xff0c;并从中提取出类、模块、函数、方法和它们之间…

电脑世界的大冒险:用人体比喻让孩子轻松理解电脑20240603

电脑世界的大冒险&#xff1a;用人体比喻让孩子轻松理解电脑 作为一名在IT行业的老程序猿&#xff0c;我见证了电脑技术的飞速发展&#xff0c;也亲身体验了科技给生活带来的翻天覆地的变化。然而&#xff0c;在这个日新月异的数字时代&#xff0c;我意识到&#xff0c;与孩子…

调用大模型API 给产业分类

文章目录 大模型API 给产业分类简要描述大模型API Tips联系方式 大模型API 给产业分类 简要描述 从全国几亿条企业工商登记数据中&#xff0c;抽取出与氢能领域的企业&#xff1b; 根据关键词匹配&#xff0c;看企业的名称和经营范围中&#xff0c;是否包含“氢”&#xff0…

Window下VS2019编译WebRTC通关版

这段时间需要实现这样一个功能&#xff0c;使用WebRTC实现语音通话功能&#xff0c;第一步要做的事情就是编译WebRTC源码&#xff0c;也是很多码友会遇到的问题。 经过我很多天的踩坑终于踩出来一条通往胜利的大路&#xff0c;下面就为大家详细介绍&#xff0c;编译步骤以及踩…

gradle wrapper properties下载gradle的换下载地址方案

修改gradle-wrapper.properties文件 #Mon Jun 03 01:40:29 CST 2024 distributionBaseGRADLE_USER_HOME distributionPathwrapper/dists # 比如说源地址是默认的,这里改为腾讯云的, 也可以其他镜像地址 distributionUrlhttps\://mirrors.cloud.tencent.com/gradle/gradle-8.6-…

安卓组合控件(底部标签栏、顶部导航栏、增强型列表、升级版翻页)

本章介绍App开发常用的一些组合控件用法&#xff0c;主要包括&#xff1a;如何实现底部标签栏、如何运用顶部导航栏、如何利用循环视图实现3种增强型列表、如何使用二代翻页视图实现更炫的翻页效果。 底部标签栏 本节介绍底部标签栏的两种实现方式&#xff1a;首先说明如何通…

初识SDN(二)

初识SDN&#xff08;二&#xff09; SDN部分实现 REST API 是什么&#xff1f; REST API&#xff08;Representational State Transfer Application Programming Interface&#xff0c;表述性状态传递应用程序接口&#xff09;是一种基于HTTP协议的接口&#xff0c;广泛用于…

minos 2.3 中断虚拟化——GICv2 管理

首发公号&#xff1a;Rand_cs 该项目来自乐敏大佬&#xff1a;https://github.com/minosproject/minos 硬件肯定需要软件配合&#xff0c;这一节就来实战 GICv2 首先准备好 GICv2 手册&#xff1a;https://developer.arm.com/documentation/ihi0048/bb/?langen&#xff0c;对…

vue3 vue-draggable-next 实现拖拽穿梭框效果

一、vue3 vue-draggable-next 实现拖拽穿梭框效果 <template> <div> <h2>列表 1</h2> <draggable v-model"list1" group"items" tag"transition-group" end"onDragEnd"> <div v-for"(item…

java中的抽象类与抽象方法

在Java中&#xff0c;抽象类和抽象方法是非常重要的概念&#xff0c;它们与面向对象编程中的多态性和继承紧密相关。以下是对Java中抽象类和抽象方法的详细介绍&#xff1a; 1. 抽象类&#xff08;Abstract Class&#xff09; 定义&#xff1a; 抽象类是一个不能被实例化的类…

C++面试题其三

继续解答常见的C面试题 继续上篇博客的解答&#xff0c;我们将进一步探讨C中的一些关键概念和常见面试问题。 29. typedef和define的区别 typedef&#xff1a;用于为现有类型定义一个新的名字。typedef是编译时的操作&#xff0c;它提供了类型别名&#xff0c;可以提高代码可…

深入剖析Java逻辑运算符,解决日常开发难题

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。运营社区&#xff1a;C站/掘金/腾讯云&#xff1b;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一…

达梦数据库的锁介绍

达梦数据库的锁介绍 达梦数据库&#xff08;DM Database&#xff09;是一款国产数据库管理系统&#xff0c;它支持多种类型的锁机制&#xff0c;用于控制并发访问&#xff0c;确保数据一致性和完整性。锁的使用是数据库并发控制中的一个重要方面&#xff0c;可以通过合理的锁机…

SpringBoot:手动创建应用

Spring提供了在线的Spring Initialzr在线创建Spring Boot项目&#xff0c;为了更好的理解Spring Boot项目&#xff0c;这里我们选择手动创建。 1.新建Web应用 1.1 生成工程 首先要做是创建一个Java项目&#xff0c;这里我们选择使用Maven来支持&#xff0c;使用archetype:ge…