给你一个输入字符串 (s
) 和一个字符模式 (p
) ,请你实现一个支持 '?'
和 '*'
匹配规则的通配符匹配:
'?'
可以匹配任何单个字符。'*'
可以匹配任意字符序列(包括空字符序列)。
判定匹配成功的充要条件是:字符模式必须能够 完全匹配 输入字符串(而不是部分匹配)。
示例 1:
输入:s = "aa", p = "a" 输出:false 解释:"a" 无法匹配 "aa" 整个字符串。
示例 2:
输入:s = "aa", p = "*" 输出:true 解释:'*' 可以匹配任意字符串。
示例 3:
输入:s = "cb", p = "?a" 输出:false 解释:'?' 可以匹配 'c', 但第二个 'a' 无法匹配 'b'。
提示:
0 <= s.length, p.length <= 2000
s
仅由小写英文字母组成p
仅由小写英文字母、'?'
或'*'
组成class Solution { public: bool isMatch(string s, string p) { int sl = s.length(); int pl = p.length(); vector<vector<bool>> dp(sl + 1, vector<bool>(pl + 1, false)); dp[0][0] = true; for (int pc = 0; pc < pl; pc++) { if (p[pc] == '*') dp[0][pc+1] = dp[0][pc]; } for (int sc = 0; sc < sl; sc++) { for (int pc = 0; pc < pl; pc++) { if (p[pc] == '?' || p[pc] == s[sc]) { dp[sc+1][pc+1] = dp[sc][pc]; }else if (p[pc] == '*') { dp[sc+1][pc+1] = dp[sc+1][pc] || dp[sc][pc+1]; } } } return dp[sl][pl]; } };
108 ms 34.12%
11.5 MB 42.32%