题目:
代码(首刷自解 2024年2月29日):
class Solution {
public:
bool isSubsequence(string s, string t) {
int m = s.size();
int n = t.size();
vector<vector<int>> dp(m + 1,vector<int>(n + 1, 0));
for (int i = 1; i <= m; ++i) {
for(int j = 1; j <= n; ++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]);
}
}
return dp[m][n] == m ? true : false;
}
};
进阶问题:
增加 if m > n return false;
将dp[]通过滚动数组降为O(1)空间复杂度,对应的循环遍历要先t后s,用两个int空间进行状态转移。