Leetcode 10 - Regular Expression Matching

Problem Description

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

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

Note:

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 *.

Java:

class Solution {
    public boolean isMatch(String s, String p) {
        if (s.length() == 0 && p.length() == 0) {
            return true;
        } else if (s.length() == 0) {
            if (p.length() % 2 != 0) {
                return false;
            } else if (p.charAt(1) == '*') {
                return isMatch(s, p.substring(2));
            } else {
                return false;
            }
        } else if (p.length() == 0) {
            return false;
        } else {
            if (s.charAt(0) == p.charAt(0)) {
                if (p.length() > 1 && p.charAt(1) == '*') {
                    return isMatch(s, p.substring(2)) || isMatch(s.substring(1), p) || isMatch(s.substring(1), p.substring(2));
                } else {
                    return isMatch(s.substring(1), p.substring(1));
                }
            } else {
                if (p.length() > 1 && p.charAt(1) == '*') {
                    return isMatch(s, p.substring(2));
                } else {
                    return false;
                }
            }
        }
    }
}

// accepted DP solution
class Solution {
    public boolean isMatch(String s, String p) {
        int[][] dp = new int[s.length()+1][p.length()+1];
        return helper(s.toCharArray(), 0, p.toCharArray(), 0, dp);
    }
    
    private boolean helper(char[] s, int si, char[] p, int pi, int[][] dp) {
        if (si == s.length && pi == p.length) return true;
        if (dp[si][pi] == 1) return false;
        
        if (si == s.length) {
            if ((p.length - pi) % 2 != 0) {
                dp[si][pi] = 1;
                return false;
            } else {
                if (p[pi+1] == '*' && helper(s, si, p, pi+2, dp)) {
                    return true;
                } 
                dp[si][pi] = 1;
                return false;
            }
        } else if (pi == p.length) {
            dp[si][pi] = 1;
            return false;
        }
        
        if (s[si] == p[pi] || p[pi] == '.') {
            if (pi + 1 != p.length && p[pi+1] == '*' && 
                (helper(s, si+1, p, pi, dp) || helper(s, si+1, p, pi+2, dp) || helper(s, si, p, pi+2, dp)) 
               || helper(s, si+1, p, pi+1, dp)) {
                return true;
            }
        } else {
            if (pi + 1 != p.length && p[pi+1] == '*' && helper(s, si, p, pi+2, dp)) {
                return true;
            }
        }
        dp[si][pi] = 1;
        return false;
    }
}

你可能感兴趣的:(Leetcode 10 - Regular Expression Matching)