10. Regular Expression Matching (JAVA)

Given an input string (s) and a pattern (p), implement regular expression matching with support for '.' and '*'.express

'.' Matches any single character.
'*' Matches zero or more of the preceding element.
The matching should cover the entire input string (not partial).spa

Note:code

s could be empty and contains only lowercase letters a-z.
p could be empty and contains only lowercase letters a-z, and characters like . or *.
Example 1:blog

Input:
s = "aa"
p = "a"
Output: false
Explanation: "a" does not match the entire string "aa".
Example 2:遞歸

Input:
s = "aa"
p = "a*"
Output: true
Explanation: '*' means zero or more of the precedeng element, 'a'. Therefore, by repeating 'a' once, it becomes "aa".
Example 3:ip

Input:
s = "ab"
p = ".*"
Output: true
Explanation: ".*" means "zero or more (*) of any character (.)".
Example 4:element

Input:
s = "aab"
p = "c*a*b"
Output: true
Explanation: c can be repeated 0 times, a can be repeated 1 time. Therefore it matches "aab".
Example 5:字符串

Input:
s = "mississippi"
p = "mis*is*p*."
Output: falseinput

class Solution {
    public boolean isMatch(String s, String p) {
        return recur(s,p,0,0);
    }
    
    public boolean recur(String s, String p, int sPtr, int pPtr) {
        if(s.length() == sPtr && p.length() == pPtr) return true;
        if(p.length() == pPtr) return false;
        if(s.length() == sPtr){
            if(p.length() > pPtr+1 && p.charAt(pPtr+1)=='*') return recur(s,p,sPtr,pPtr+2);
            else return false;
        }
        
        if(p.length() > pPtr+1 && p.charAt(pPtr+1)=='*'){ //next bit is *
            if(recur(s,p,sPtr,pPtr+2)) return true; //* match 0 element
            else{
                for(int i = 1; sPtr + i <= s.length() && (p.charAt(pPtr)==s.charAt(sPtr+i-1)|| p.charAt(pPtr)=='.'); i++){
                    if(recur(s,p,sPtr+i,pPtr+2)) return true; //* match i elements
                }
            } 
        }
        else if(p.charAt(pPtr)=='.' || p.charAt(pPtr)==s.charAt(sPtr)) 
            return recur(s, p, sPtr+1, pPtr+1);
        
        return false;
    }
}

噹噹前字符以後的那個字符是*時,咱們須要對當前字符作特別判斷,因此沒次遞歸中要判斷p字符串的下一個字符是不是*string

相關文章
相關標籤/搜索