給定一個字符串?(s) 和一個字符模式?(p) ,實現一個支持?'?'?和?'*'?的通配符匹配。
'?' 可以匹配任何單個字符。
'*' 可以匹配任意字符串(包括空字符串)。
兩個字符串完全匹配才算匹配成功。
說明:
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 = "*a*b"
輸出: true
解釋:?第一個 '*' 可以匹配空字符串, 第二個 '*' 可以匹配字符串 "dce".
示例?5:
輸入:
s = "acdcb"
p = "a*c?b"
輸入: false
思路:和leetcode10差不多,只不過這個*可以代表任意字符,并且和前一個字符沒關系,dp式子好推很多。
class Solution {public boolean isMatch(String s,String p){if (s == null || p == null)return false;int sLen=s.length();int pLen=p.length();boolean[][] dp = new boolean[sLen + 1][pLen + 1];dp[0][0] = true;//dp[i][j] 表示 s 的前 i 個是否能被 p 的前 j 個匹配for (int j=1;j<=pLen;j++)dp[0][j]=p.charAt(j-1)=='*' && dp[0][j-1];for (int i = 0; i < sLen; i++) {for (int j = 0; j < pLen; j++) {//單個字符可以匹配if (p.charAt(j) == '?' || p.charAt(j) == s.charAt(i)) dp[i + 1][j + 1] = dp[i][j];//多個字符if (p.charAt(j) == '*') {dp[i+1][j+1]=dp[i+1][j] || //*代表0個dp[i][j+1]; //代表多個}}}return dp[sLen][pLen];}
}
?