- 正则表达式匹配
给你一个字符串 s 和一个字符规律 p,请你来实现一个支持 ‘.’ 和 ‘*’ 的正则表达式匹配。
‘.’ 匹配任意单个字符
‘*’ 匹配零个或多个前面的那一个元素
所谓匹配,是要涵盖 整个 字符串 s的,而不是部分字符串。
说明:
s 可能为空,且只包含从 a-z 的小写字母。
p 可能为空,且只包含从 a-z 的小写字母,以及字符 . 和 *。
public boolean isMatch(String s, String p) {
//考虑特殊情况,如果p是"",那么只有当s也是""才能匹配。
if(p.length()==0)
return s.length()==0;
//当s的长度不为空,并且p的第一个字符和s的第一字符相等或者是'.',则表明第一个字符是匹配的。
boolean first_match=false;
first_match=(s.length()!=0)&&(p.charAt(0)=='.'||p.charAt(0)==s.charAt(0));
//如果我们匹配到了'*', 我们要么用'*'匹配0次(直接从'*'后面再继续匹配),要么只匹配1次
if(p.length()>=2&&p.charAt(1)=='*')
return isMatch(s,p.substring(2))||(first_match&&isMatch(s.substring(1), p));
//如果没有匹配到'*',则继续匹配剩下的字符串
else
return first_match&&isMatch(s.substring(1), p.substring(1));
}