题目链接:392. 判断子序列 - 力扣(LeetCode)
代码如下:
class Solution {
public:
bool isSubsequence(string s, string t) {
int len1 = s.size();
int len2 = t.size();
int result = 0;
vector<vector<int> > dp(len1 + 1, vector<int>(len2 + 1, 0));
for(int i = 1; i <= len1; i++)
{
for(int j = 1; j <= len2; j++)
{
if(s[i - 1] == t[j - 1])
{
dp[i][j] = dp[i - 1][j - 1] + 1;
}
else
{
dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
}
if(dp[i][j] > result)
{
result = dp[i][j];
}
}
}
if(result == len1)
{
return true;
}
return false;
}
};
这个判断自序列其实就是和之前的判断公共,重复子序列一样,就只是返回的值不一样,思路完全一模一样
类型题详细介绍:LeetCode718:最长重复子数组-CSDN博客
LeetCode1035:1035. 不相交的线 - 力扣(LeetCode)
这个题目其实和不相交的线也是一样的,不相交的线其实都可以转换为这个公共子序列问题来编写
这都是一系列问题