闫氏DP分析法
C ++ 代码
class Solution {
public:
bool isMatch(string s, string p) {
int n = s.size(), m = p.size();
s = ' ' + s, p = ' ' + p; //为了下标从1开始
vector<vector<bool>> f(n + 1, vector<bool> (m + 1));
f[0][0] = true;
for (int i = 0; i <= n; i ++) //第一个串为空时,可能匹配,因为'*' 可匹配零个,所以下标可从0开始
for (int j = 1; j <= m; j ++)
{
if (j + 1 < p.size() && p[j + 1] == '*') continue; //当前位应该和下一位看作整体;
if (i && p[j] != '*') //状态转移需要用到i - 1, 所以需要保证i > 0
{
f[i][j] = f[i - 1][j - 1] && (s[i] == p[j] || p[j] == '.');
}
else if (p[j] == '*')
{
f[i][j] = f[i][j - 2] || i && f[i - 1][j] && (s[i] == p[j - 1] || p[j - 1] == '.'); //&&优先级 > ||
}
}
return f[n][m];
}
};
现在好像最后一个用例过不了了
厉害
转换
f[i-1][j]为
f[i][j]`的时候第二行的式子最后不是会多出来一项与上面无法对应吗?在f[i - 1][j] 转换成 f[i][j] 时,在f[i - 1][j]第一项是 f[i - 1][j-2]吧? 为什么直接可以与f[i][j] 的第二项即 f[i - 1][j-2]&& s[i] == p[j - 1] 相对应呢?是因为s[i] == p[j - 1] 被移动到了外面,先||再&&
写得非常好,尤其是递推的最后一步有点类似完全背包
优化那里的等式右边第二个项应该是f(i-2,j-2)吧
已改正,谢谢!
这里的““可以匹配0或多个的意思是这样的吗:
a可以为“ ”,可以为a,可以为aa,可以为aaaaa.....
ipad用来干这个好方便
这个dp分析做的真是太棒了
赞一个