LeetCode 115. 不同的子序列

这篇博客介绍了LeetCode 115题目的详细解题过程,包括题目描述、解题思路和程序代码。题目要求计算字符串S中子序列T的出现次数,保证答案在32位整数范围内。博客提供了递归解法作为思路的起点,并指出如何转化为记忆化搜索和最终的动态规划解决方案。
摘要由CSDN通过智能技术生成

题目链接 LeetCode 115. 不同的子序列

题目描述

给定一个字符串 S 和一个字符串 T,计算在 S 的子序列中 T 出现的个数。

一个字符串的一个子序列是指,通过删除一些(也可以不删除)字符且不干扰剩余字符相对位置所组成的新字符串。(例如,“ACE” 是 “ABCDE” 的一个子序列,而 “AEC” 不是)

题目数据保证答案符合 32 位带符号整数范围。

示例 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
^^^

解题思路

当初搞信息竞赛的时候对DP掌握的就很差,现在得重新来过了,所以我们就从一开始的递归解法开始吧。

很多DP题目都可用递归来做,当然不能过掉全部的数据,但是我们可以用递归来找思路,然后再转化成记忆化搜索,最后优化成DP,是一个很好的思路。

首先得搞清楚一个问题,不论是递归还是DP,都要搞清楚这个问题所涉及的所有状态,哪些状态是对提供答案有用的,哪些是没用的,如果状态不清楚的话就很难进行下一步操作。

在这道题中,我们先来找哪些状态可以对提供答案有用。
①如果s[i]==t[j]
我们有两种选择
第一种即当前s[i]和t[j]相匹配,两个指针都往下一个移动。
第二种就是不用当前的s[i]和t[j]匹配,而是用下一个s[i+1]和t[j]去匹配,因为有可能出现 i 位置上和 i+1 位置上都是相同的,可以有选择的用哪一个来匹配。

②如果s[i]!=t[j]
那么 i 指针往下一个移动, j 指针不移动。

根据这几个状态我们就可以写出递归的程序,进而也就可以写出DP的程序代码。

程序代码

递归版

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int dfs(string s,string t,int i,
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值