lintcode-118-不同的子序列
2024-08-23 07:17:24
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];
}
};
最新文章
- COGS 265线段覆盖[线段树]
- 使用F#来实现哈夫曼编码吧
- 【转】虚拟机VMware3种网络模式(桥接、nat、Host-only)的工作原理
- javaweb学习总结(十八)——JSP属性范围
- 17.(转) Android之四大基本组件介绍与生命周期
- 【leetcode❤python】198. House Robber
- MongoDB数据访问[C#]附源码下载(查询增删改) 转载
- centos7的网络配置以及设置主机名和绑定IP的问题
- PHP-通过strace定位故障原因
- HeadFirst设计模式之策略模式
- div整体布局分析
- linux面试题集锦4《转》
- java调用shell脚本,并获得结果集的例子
- Spring Cloud 入门教程 - Eureka服务注册与发现
- sql server 性能调优之 资源等待PAGEIOLATCH
- ArcMap2Sld:一个将MXD中图层配图样式转换为OGC的SLD文件的开源工具
- Vagrant工具的安装
- python 全栈开发,Day106(结算中心(详细),立即支付)
- mfc 进程的优先级
- golang学习 ----获取URL
热门文章
- spring mvc 数据绑定入门
- 2018/7/19 考试(tower,work,holes)
- 安装mysqlclient报OSError: mysql_config not found
- Ganglia监控安装配置
- android发布帖子类技术
- Mysql导出表结构和数据
- Redis缓存数据库的安装与配置(1)
- java图片识别 [Tesseract-OCR]
- .net Core错误记录
- Ubuntu无法安装vim怎么办?(Ubuntu 出现apt-get: Package has no installation candidate问题)