118-不同的子序列

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

子序列字符串是原始字符串通过删除一些(或零个)产生的一个新的字符串,并且对剩下的字符的相对位置没有影响。(比如,“ACE”是“ABCDE”的子序列字符串,而“AEC”不是)。

样例

给出S = "rabbbit", T = "rabbit"

返回 3

挑战

Do it in O(n2) time and O(n) memory.

O(n2) memory is also acceptable if you do not know how to optimize memory.

标签

字符串处理 动态规划

思路

使用动态规划,首先考虑辅助空间为 O(n^2) 的情况,使用二维数组 dp[i][j] 表示 S[0...i] 中 T[0...j] 出现的个数

动态转移方程为:

dp[i][j] = dp[i-1][j-1] + dp[i-1][j] (S[i]==T[j])

dp[i][j] = dp[i-1][j] (S[i]!=T[j])

过程如下:



过程中发现,新的取值仅仅和其左上和上部元素有关,所以可以用一维数组 dp[i] 代替二维数组

code

class Solution {
public:
/**
* @param S, T: Two string.
* @return: Count the number of distinct subsequences
*/
int numDistinct(string &S, string &T) {
// write your code here
int sizeS = S.size(), sizeT = T.size(), i = 0, j = 0;
if(sizeS <= 0 || sizeT <= 0) {
return 1;
} vector<int> dp(sizeT+1, 0);
dp[0] = 1; for(i=1; i<=sizeS; i++) {
for(j=sizeT; j>0; j--) {
if(S[i-1] == T[j-1]) {
dp[j] += dp[j-1];
}
}
}
return dp[sizeT];
}
};

最新文章

  1. COGS 265线段覆盖[线段树]
  2. 使用F#来实现哈夫曼编码吧
  3. 【转】虚拟机VMware3种网络模式(桥接、nat、Host-only)的工作原理
  4. javaweb学习总结(十八)——JSP属性范围
  5. 17.(转) Android之四大基本组件介绍与生命周期
  6. 【leetcode❤python】198. House Robber
  7. MongoDB数据访问[C#]附源码下载(查询增删改) 转载
  8. centos7的网络配置以及设置主机名和绑定IP的问题
  9. PHP-通过strace定位故障原因
  10. HeadFirst设计模式之策略模式
  11. div整体布局分析
  12. linux面试题集锦4《转》
  13. java调用shell脚本,并获得结果集的例子
  14. Spring Cloud 入门教程 - Eureka服务注册与发现
  15. sql server 性能调优之 资源等待PAGEIOLATCH
  16. ArcMap2Sld:一个将MXD中图层配图样式转换为OGC的SLD文件的开源工具
  17. Vagrant工具的安装
  18. python 全栈开发,Day106(结算中心(详细),立即支付)
  19. mfc 进程的优先级
  20. golang学习 ----获取URL

热门文章

  1. spring mvc 数据绑定入门
  2. 2018/7/19 考试(tower,work,holes)
  3. 安装mysqlclient报OSError: mysql_config not found
  4. Ganglia监控安装配置
  5. android发布帖子类技术
  6. Mysql导出表结构和数据
  7. Redis缓存数据库的安装与配置(1)
  8. java图片识别 [Tesseract-OCR]
  9. .net Core错误记录
  10. Ubuntu无法安装vim怎么办?(Ubuntu 出现apt-get: Package has no installation candidate问题)