392.判断子序列
这里的dp含义应该是长度为i-1的s在j-1的t中所能完整匹配到的最大长度(完整匹配指的是长度为j-1的t中的对应子序列是完整的s,也就是说最大长度一旦存在一定是i-1)
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.不同的子序列
这里的数据量很大!注意使用的参数类型!
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 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()];
}
};