难度:困难
题目描述:
请实现一个函数用来匹配包含’. ‘和’‘的正则表达式。模式中的字符’.’表示任意一个字符,而’‘表示它前面的字符可以出现任意次(含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];}
