題目:、
給定乙個字串 (s) 和乙個字元模式 (p) ,實現乙個支援 '?' 和 '*' 的萬用字元匹配。
'?' 可以匹配任何單個字元。
'*' 可以匹配任意字串(包括空字串)。
兩個字串完全匹配才算匹配成功。
說明:s 可能為空,且只包含從 a-z 的小寫字母。
p 可能為空,且只包含從 a-z 的小寫字母,以及字元 ? 和 *。
示例 1:
輸入:s = "aa"
p = "a"
輸出: false
解釋: "a" 無法匹配 "aa" 整個字串。
示例 2:
輸入:s = "aa"
p = "*"
輸出: true
解釋: '*' 可以匹配任意字串。
思路:匹配總共分三種情況:
1、模式第乙個與字串第乙個相等或者模式第乙個為「?」(代表任意):
直接模式和字串都加1;
2.模式當前是「*」:
記錄當前「*」開始匹配的位置,字串往下走,模式不變。
因為「*」可以匹配任意字串
3.匹配到有不符合的了,若模式之前有「*」,讓「*」多匹配乙個字元。
繼續往下走
以上都不是,匹配不成功。
注意
注意模式中有*,可以讓*匹配剩餘字串
判斷字串為空和模式為空的情況
class solution(object):
def ismatch(self, s, p):
""":type s: str
:type p: str
:rtype: bool
"""i,j,start,end=0,0,-1,0
while iif ji+=1
j+=1
elif jstart=j
end=i
j+=1
elif start!=-1:
end+=1
j=start+1
i=end
else:
return false
return all(x == "*" for x in p[j:])
44 萬用字元匹配
題目描述 提示幫助 提交記錄社群討論閱讀解答 隨機一題 給定乙個字串 s 和乙個字元模式 p 實現乙個支援 和 的萬用字元匹配。可以匹配任何單個字元。可以匹配任意字串 包括空字串 兩個字串完全匹配才算匹配成功。說明 示例 1 輸入 s aa p a 輸出 false解釋 a 無法匹配 aa 整個字串...
44 萬用字元匹配
題目.high 以pattern字串做遞迴,每次減少最後的乙個pattern字元。可以發現是個遞迴子問題,所以用dp比較合適 package main import fmt func ismatch s string p string bool dp 0 0 true for j 1 j len p...
44 萬用字元匹配
給定乙個字串 s 和乙個字元模式 實現乙個支援 和 的萬用字元匹配。可以匹配任何單個字元。可以匹配任意字串 包括空字串 兩個字串完全匹配才算匹配成功。說明 s 可能為空,且只包含從 a z 的小寫字母。p 可能為空,且只包含從 a z 的小寫字母,以及字元 和 示例 1 輸入 s aa p a 輸出...