【LeetCode】10. Regular Expression Matching

題目:java

  Implement regular expression matching with support for '.' and '*'.express

  '.' Matches any single character.
  '*' Matches zero or more of the preceding element.

思路:'.' 表明任意單字符,'*' 能夠表明將前面的字符去掉,也能夠表明是對前面字符(包括'.')的重複(數目無限)。例子:code

    aa  a     //不匹配,很明顯blog

    aa  aa     //匹配element

    aaa  aa     //不匹配字符串

    aa  a*    //匹配,*重複astring

    aa  .*    //匹配,.表明a,*重複ait

    ab  .*    //匹配,.表明a,*重複.自己(不是.表明的a),表明b          也就是說.*能夠是..   ...   .....等等,可匹配任意字符串io

    aab  c*a*b  //匹配,第一個*將c字符去掉,aab與a*b很明顯匹配class

public class Solution {
    public boolean isMatch(String s, String p) {
        /*
        if(p.length()==0){
            return s.length()==0;
        }
        
        if(p.length()==1){
            return s.length()==1&&(p.charAt(0)==s.charAt(0)||p.charAt(0)=='.');
        }
        
        if(p.charAt(1)=='*'){
            if(isMatch(s,p.substring(2))){
                return true;
            }
            return s.length()>0&&(p.charAt(0)==s.charAt(0)||p.charAt(0)=='.')&&isMatch(s.substring(1),p);
        }else{
            return s.length()>0&&(p.charAt(0)==s.charAt(0)||p.charAt(0)=='.')&&isMatch(s.substring(1),p.substring(1));
        }
        */
        return isMatch(s, 0, p, 0);
    }
    private boolean isMatch(String s, int i, String p, int j) {
		int ls = s.length();
		int lp = p.length();
		if (j == lp) {
			return i == ls;
		}
		// case 1: when the second char of p is not '*'
		if ((j < lp - 1 && p.charAt(j + 1) != '*') || j == lp - 1) {
			return (i < ls && s.charAt(i) == p.charAt(j) || p.charAt(j) == '.') && isMatch(s, i + 1, p, j + 1);
		}
		// case 2: when the second char of p is '*', complex case.
		while ((i < ls && s.charAt(i) == p.charAt(j)) || (p.charAt(j) == '.' && i < ls)) {
			if (isMatch(s, i, p, j + 2))
				return true;
			i++;
		}
		return isMatch(s, i, p, j + 2);
	}
}
相關文章
相關標籤/搜索