1 Star 0 Fork 0

ydsungan/algorithm

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
test_35_num_distinct.cpp 836 Bytes
一键复制 编辑 原始数据 按行查看 历史
ydsungan 提交于 2021-10-23 21:38 +08:00 . 1023-周六-晚上
#include <iostream>
#include <string>
#include <string.h>
using namespace std;
int numDistinct(string s, string t) {
int m = s.size();
int n = t.size();
if (n > m) return 0;
int dp[m+1][n+1];
memset(dp, 0, sizeof(dp));
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 (t[j-1] == s[i-1]) {
dp[i][j] = dp[i-1][j-1] + dp[i-1][j];
} else {
dp[i][j] = dp[i-1][j];
}
}
}
for (int i = 0; i <= m; i++) {
for (int j = 0; j <= n; j++) {
cout << dp[i][j] << " ";
}
cout << endl;
}
return dp[m][n];
}
int main(){
string s = "carrotr";
string t = "car";
cout << numDistinct(s, t) << endl;
return 0;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/ydsungan/algorithm.git
git@gitee.com:ydsungan/algorithm.git
ydsungan
algorithm
algorithm
master

搜索帮助