难度:困难
题目描述:
请实现一个函数用来匹配包含’. ‘和’‘的正则表达式。模式中的字符’.’表示任意一个字符,而’‘表示它前面的字符可以出现任意次(含0次)。在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串”aaa”与模式”a.a”和”abaca”匹配,但与”aa.a”和”ab*a”均不匹配。
示例:
输入:
s = "aa"
p = "a"
输出: false
解释: "a" 无法匹配 "aa" 整个字符串。
解题思路:
var isMatch = function(s, p) {
let m = s.length;
let n = p.length;
let dp = Array.from({length: m+1},x=>new Array(n+1).fill(false));
dp[0][0] = true;
for(let i = 0; i <= m;i++) {
for(let j = 1; j <= n; j++) {
if(p[j-1] === "*") {
dp[i][j] = dp[i][j-2];
if(match(s,p,i,j-1)) {
dp[i][j] = dp[i][j] || dp[i-1][j];
}
} else {
if(match(s,p,i,j)) {
dp[i][j] = dp[i-1][j-1];
}
}
}
}
return dp[m][n];
};
const match = (s,p,i,j)=> {
if(i === 0) return false;
if(p[j-1] === '.') return true;
return s[i-1] === p[j-1];
}