题目描述
请实现一个函数用来匹配包括’.‘和’‘的正则表达式。模式中的字符’.‘表示任意一个字符,而’'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"abaca"匹配,但是与"aa.a"和"ab*a"均不匹配
public class Solution {
public boolean match(char[] str, char[] pattern)
{
return judge(str,0,pattern,0);
}
public boolean judge(char[] s,int a,char[] p,int b){
int ls=s.length;
int lp=p.length;
if(a==ls&&b==lp) return true;
else if(b==lp) return false;
if(b+1<lp&&p[b+1]=='*'){
if(a<ls&&(s[a]==p[b]||p[b]=='.')){
return judge(s,a+1,p,b)||judge(s,a+1,p,b+2)||judge(s,a,p,b+2);
}
else{
return judge(s,a,p,b+2);
}
}
else{
if(a<ls&&(s[a]==p[b]||p[b]=='.')){
return judge(s,a+1,p,b+1);
}
else{
return false;
}
}
}
}