(leetcode刷题)
通配符匹配
题目: 给定一个字符串 (s) 和一个字符模式 § ,实现一个支持 ‘?’ 和 ‘*’ 的通配符匹配。
- ‘?’ 可以匹配任何单个字符。
- ‘*’ 可以匹配任意字符串(包括空字符串)。
- s 可能为空,且只包含从 a-z 的小写字母。
- p 可能为空,且只包含从 a-z 的小写字母,以及字符 ? 和 *。
示例: 输入:s = "aa",p = "a"
;输出: False
方法
- 递归容易超时,所以动态规划可能更好。
class Solution:
def isMatch(self, s: str, p: str) -> bool:
lens,lenp = len(s),len(p)
dp = [[False] * (lenp + 1) for _ in range(lens + 1)]
dp[0][0] = True
for j in range(1, lenp + 1):
if p[j - 1] == "*":
dp[0][j] = dp[0][j - 1]
for i in range(1, sn + 1):
for j in range(1, pn + 1):
if (s[i - 1] == p[j - 1] or p[j - 1] == "?"):
dp[i][j] = dp[i - 1][j - 1]
elif p[j - 1] == "*":
dp[i][j] = dp[i - 1][j] or dp[i][j - 1]
return dp[-1][-1]