时间限制:1秒 空间限制:32768K 热度指数:240361
本题知识点: 字符串
题目描述
请实现一个函数用来匹配包括'.'和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"ab*ac*a"匹配,但是与"aa.a"和"ab*a"均不匹配
方法:动态规划
代码如下:
class Solution {
public:
bool match(char* str, char* pattern) {
int m = strlen(str), n = strlen(pattern);
vector<vector<bool>> dp(m + 1, vector<bool>(n + 1, false));
dp[0][0] = true;
for (int i = 0; i <= m; ++i) {
for (int j = 1; j <= n; ++j) {
if (j > 1 && pattern[j - 1] == '*') {//匹配0个a的情况,1个a的情况或者匹配多个a的 情况
dp[i][j] = dp[i][j - 2] || (i > 0 && (str[i - 1] == pattern[j - 2] || pattern[j - 2] == '.') && dp[i - 1][j]);
} else {
dp[i][j] = i > 0 && dp[i - 1][j - 1] && (str[i - 1] == pattern[j - 1] || pattern[j - 1] == '.');
}
}
}
return dp[m][n];
}
};