給你一個字符串?s?和一個字符規律?p,請你來實現一個支持 '.'?和?'*'?的正則表達式匹配。
'.' 匹配任意單個字符
'*' 匹配零個或多個前面的那一個元素
所謂匹配,是要涵蓋?整個?字符串?s的,而不是部分字符串。
說明:
s?可能為空,且只包含從?a-z?的小寫字母。
p?可能為空,且只包含從?a-z?的小寫字母,以及字符?.?和?*。
示例 1:
輸入:
s = "aa"
p = "a"
輸出: false
解釋: "a" 無法匹配 "aa" 整個字符串。
示例 2:
輸入:
s = "aa"
p = "a*"
輸出: true
解釋:?因為 '*' 代表可以匹配零個或多個前面的那一個元素, 在這里前面的元素就是 'a'。因此,字符串 "aa" 可被視為 'a' 重復了一次。
示例?3:
輸入:
s = "ab"
p = ".*"
輸出: true
解釋:?".*" 表示可匹配零個或多個('*')任意字符('.')。
示例 4:
輸入:
s = "aab"
p = "c*a*b"
輸出: true
解釋:?因為 '*' 表示零個或多個,這里 'c' 為 0 個, 'a' 被重復一次。因此可以匹配字符串 "aab"。
示例 5:
輸入:
s = "mississippi"
p = "mis*is*p*."
輸出: false
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 i = 0; i < pLen; i++) {dp[0][i + 1] = p.charAt(i) == '*' && dp[0][i - 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-1] || //*代表0個(dp[i+1][j] && (s.charAt(i)==p.charAt(j-1) || p.charAt(j-1)=='.')) || //*代表1個(dp[i][j+1] && (s.charAt(i)==p.charAt(j-1) || p.charAt(j-1)=='.')); //代表多個}}}return dp[sLen][pLen];}
}
?