題目:給定一個字符串 (s) 和一個字符模式 (p) ,實現(xiàn)一個支持 '?' 和 '*' 的通配符匹配。
'?' 可以匹配任何單個字符。
'*' 可以匹配任意字符串(包括空字符串)。
兩個字符串完全匹配才算匹配成功。
說明:
s 可能為空,且只包含從 a-z 的小寫字母。
p 可能為空,且只包含從 a-z 的小寫字母,以及字符 ? 和 *。
示例 1:
輸入:
s = "aa"
p = "a"
輸出: false
解釋: "a" 無法匹配 "aa" 整個字符串。
示例 2:
輸入:
s = "aa"
p = ""
輸出: true
解釋: '' 可以匹配任意字符串。
示例 3:
輸入:
s = "cb"
p = "?a"
輸出: false
解釋: '?' 可以匹配 'c', 但第二個 'a' 無法匹配 'b'。
示例 4:
輸入:
s = "adceb"
p = "ab"
輸出: true
解釋: 第一個 '' 可以匹配空字符串, 第二個 '' 可以匹配字符串 "dce".
示例 5:
輸入:
s = "acdcb"
p = "a*c?b"
輸入: fals
解法:
var isMatch = function(s, p) {
let cur = new Array(s.length + 1).fill(false)
cur[0] = true
for (const c of p) {
if (c == '*'){
let begin = cur.indexOf(true)
if (begin == -1) {
return false
}
cur.fill(true, begin)
} else {
for(let j = s.length;j > 0; --j){
cur[j] = (c == '?' || c == s[j-1]) && cur[j-1]
}
cur[0] = false
}
}
return cur[s.length]
};