Distinct Subsequences(不同子序列的个数)——b字符串在a字符串中出现的次数、动态规划
Given a string S and a string T, count the number of distinct subsequences ofT inS.
A subsequence of a string is a new string which is formed from the original string by deleting some (can be none) of the characters without disturbing the relative positions of the remaining characters. (ie,"ACE" is a subsequence of"ABCDE" while "AEC" is not).
Here is an example:
S = "rabbbit", T = "rabbit"
Return 3.
简单翻译一下,给定两个字符串S和T,求S有多少个不同的子串与T相同。S的子串定义为在S中任意去掉0个或者多个字符形成的串。
递归求解:
首先找到在S中与T的第一个字符相同的字符,从这个字符开始,递归地求S和T剩下的串。T为空串时,返回1。因为空串本身是另外一个串的一个子序列。这个算法实现简单,但是果然不出意料,大集合超时。
Java代码:
 public int numDistinct(String S, String T) {
   // Start typing your Java solution below
   // DO NOT write main() function
   if (S.length() == 0) {
     return T.length() == 0 ? 1 : 0;
   }
   if (T.length() == 0) {
     return 1;
   }
   int cnt = 0;
   for (int i = 0; i < S.length(); i++) {
     if (S.charAt(i) == T.charAt(0)) {
       cnt += numDistinct(S.substring(i + 1), T.substring(1));
     }
   }
   return cnt;
 }  
遇到这种两个串的问题,很容易想到DP。但是这道题的递推关系不明显。可以先尝试做一个二维的表int[][] dp,用来记录匹配子序列的个数(以S ="rabbbit",T = "rabbit"为例):
r a b b b i t
1 1 1 1 1 1 1 1
r 0 1 1 1 1 1 1 1
a 0 0 1 1 1 1 1 1
b 0 0 0 1 2 3 3 3
b 0 0 0 0 1 3 3 3
i 0 0 0 0 0 0 3 3
t 0 0 0 0 0 0 0 3
从这个表可以看出,无论T的字符与S的字符是否匹配,dp[i][j] = dp[i][j - 1].就是说,假设S已经匹配了j - 1个字符,得到匹配个数为dp[i][j - 1](即若S[j]!=T[i],则该出现次数等于T[0-i]在S[0-(j-1)]出现的次数).现在无论S[j]是不是和T[i]匹配,匹配的个数至少是dp[i][j - 1]。除此之外,当S[j]和T[i]相等时,我们可以让S[j]和T[i]匹配,然后让S[j - 1]和T[i - 1]去匹配(T[0-(i-1)]在S[0-(j-1)]出现的次数*(T[i]==S[j])=1)
所以递推关系为:
dp[0][0] = 1; // T和S都是空串.
dp[0][1 ... S.length() - 1] = 1; // T是空串,S只有一种子序列匹配。
dp[1 ... T.length() - 1][0] = 0; // S是空串,T不是空串,S没有子序列匹配。
dp[i][j] = dp[i][j - 1] + (T[i - 1] == S[j - 1] ? dp[i - 1][j - 1] : 0).1 <= i <= T.length(), 1 <= j <= S.length()
 class Solution {
 public:
     int numDistinct(string S, string T) {
         if(S.empty()||T.empty()) return ;
         if(S.length()<T.length()) return ;
         int dp[T.length()+][S.length()+];
         dp[][]=;
         for(int i=;i<=T.length();i++){
             dp[i][]=;
         }
         for(int j=;j<=S.length();j++){
             dp[][j]=;
         }
         for(int i=;i<=T.length();i++){
             for(int j=;j<=S.length();j++){
                 dp[i][j]=dp[i][j-];
                 if(T[i-]==S[j-])
                     dp[i][j]+=dp[i-][j-];
             }
         }
         return dp[T.length()][S.length()];
     }
 };
Distinct Subsequences(不同子序列的个数)——b字符串在a字符串中出现的次数、动态规划的更多相关文章
- java程序员的从0到1:统计某字符串在某文件中出现的次数(面试题)
		目录: 1. 编程题目 2. 方法一 3. 方法二 4. 方法三 5. 方法四 6. 总结 正文: 1. 编程题目 写一个方法,输入一个文件名和一个字符串,统计这个字符串在这个文件中出现的次数. 2. ... 
- 子序列 sub sequence问题,例:最长公共子序列,[LeetCode] Distinct Subsequences(求子序列个数)
		引言 子序列和子字符串或者连续子集的不同之处在于,子序列不需要是原序列上连续的值. 对于子序列的题目,大多数需要用到DP的思想,因此,状态转移是关键. 这里摘录两个常见子序列问题及其解法. 例题1, ... 
- [Leetcode] distinct subsequences 不同子序列
		Given a string S and a string T, count the number of distinct subsequences of T in S. A subsequence ... 
- 115 Distinct Subsequences 不同子序列
		给定一个字符串 S 和一个字符串 T,求 S 的不同的子序列中 T 出现的个数.一个字符串的一个子序列是指:通过删除一些(也可以不删除)字符且不干扰剩余字符相对位置所组成的新字符串.(譬如," ... 
- [LeetCode] Distinct Subsequences 不同的子序列
		Given a string S and a string T, count the number of distinct subsequences of T in S. A subsequence ... 
- [LeetCode] 115. Distinct Subsequences 不同的子序列
		Given a string S and a string T, count the number of distinct subsequences of S which equals T. A su ... 
- 在论坛中出现的比较难的sql问题:27(字符串拆分、字符串合并、非连续数字的间隔范围、随机返回字符串)
		原文:在论坛中出现的比较难的sql问题:27(字符串拆分.字符串合并.非连续数字的间隔范围.随机返回字符串) 在论坛中看到一个帖子,帖子中有一些sql方面的面试题,我觉得这些面试题很有代表性. 原帖的 ... 
- [leetcode]115. Distinct Subsequences 计算不同子序列个数
		Given a string S and a string T, count the number of distinct subsequences of S which equals T. A su ... 
- [Swift]LeetCode115. 不同的子序列 | Distinct Subsequences
		Given a string S and a string T, count the number of distinct subsequences of S which equals T. A su ... 
随机推荐
- Leetcode 436.寻找右区间
			寻找右区间 给定一组区间,对于每一个区间 i,检查是否存在一个区间 j,它的起始点大于或等于区间 i 的终点,这可以称为 j 在 i 的"右侧". 对于任何区间,你需要存储的满足条 ... 
- CodeM初赛B轮
			做什么啊,我这么菜,应该弃赛的 [编程|1500分] 子串 时间限制:3秒空间限制:32768K 题目描述 给出一个正整数n,我们把1..n在k进制下的表示连起来记为s(n,k),例如s(16,16) ... 
- element-ui 的input组件 @keyup.enter事件的添加办法
			<el-input placeholder="请输入密码" type="password" @keyup.enter.native="login ... 
- 'Add Solution': A timeout has occurred while invoking commands in SharePoint host process.
			一.问题描述: 在部署SharePoint solution的时候,出现Time out 的问题,错误提示: Error occurred in deployment step 'Add Soluti ... 
- windows8.1如何分盘
			磁盘分区首先要弄明白磁盘物理顺序与逻辑顺序的区别,在[磁盘管理]界面,所显示的前后顺序为物理顺序,这是磁盘上实实在在的物理位置,如下图2的电脑磁盘物理顺序为CFDE.在[资源管理器]界面,所显示的顺序 ... 
- TinyXML2使用教程(转)
			原文转自 http://blog.csdn.net/K346K346/article/details/48750417 1.TinyXML2概述 TinyXML2是simple.small.effic ... 
- brk(), sbrk() 用法详解【转】
			转自:http://blog.csdn.net/sgbfblog/article/details/7772153 贴上原文地址,好不容易找到了:brk(), sbrk() -- 改变数据段长度 brk ... 
- MySQL的一个麻烦事
			1. 开启一个MySQL连接,在这个连接中发起一个事务,进行一些操作但不提交 2. 拔网线 3. 重连网线,再开启一个MySQL连接,执行delete操作,发现stpe 1中占用的资源没有被释放 4. ... 
- vue 权限控制按钮3种样式、内容、以及跳转事件
			最近碰到一个因为要根据权限来给一个按钮变成不同功能, 简单写出3个按钮然后用v-if也能实现这个功能,但是在加载页面时,如果延迟过高则会把按钮按照DOM顺序加载出来,这是个很不好的效果 思索了下,把三 ... 
- vue v-show与v-for同时配合v-bind使用并在href中传递多个参数的使用方法
			最近在项目中,因为还没使用前端构建工具,还在使用vue+jquery方法渲染页面 碰到几个小问题,在此记录下作为vue学习之路上的一个小知识点 需求:1.数据列表存在与否状态,没有数据显示默认提示,有 ... 
