代码随想录Day55——392.判断子序列 115.不同的子序列
2023-12-18 12:09:01
392.判断子序列
给定字符串?s?和?t?,判断?s?是否为?t?的子序列。
字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace"
是"abcde"
的一个子序列,而"aec"
不是)。
class Solution {
public:
bool isSubsequence(string s, string t) {
vector<vector<int>> dp(s.size()+1,vector<int>(t.size()+1,0));
for(int i = 1;i<=s.size();i++)
{
for(int j = 1;j<=t.size();j++)
{
if(s[i-1] == t[j-1]) dp[i][j] = dp[i-1][j-1]+1;
else dp[i][j] = dp[i][j-1];
}
}
if(dp[s.size()][t.size()] == s.size()) return true;
else return false;
}
};
115.不同的子序列 ?
给你两个字符串?s
?和?t
?,统计并返回在?s
?的?子序列?中?t
?出现的个数,结果需要对?109?+ 7 取模。
class Solution {
public:
int numDistinct(string s, string t) {
vector<vector<uint64_t>> dp(s.size()+1,vector<uint64_t>(t.size()+1,0));
for(int j = 1;j<t.size();j++) dp[0][j] = 0;
for(int i = 0;i<s.size();i++) dp[i][0] = 1;
for(int i = 1;i<=s.size();i++)
{
for(int j = 1;j<=t.size();j++)
{
if(s[i-1] == t[j-1]) dp[i][j] = dp[i-1][j-1] + dp[i-1][j];
else dp[i][j] = dp[i-1][j];
}
}
return dp[s.size()][t.size()];
}
};
文章来源:https://blog.csdn.net/cheng_dog/article/details/135057460
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!