LeetCode刻意练习18--正则表达式匹配

  1. 正则表达式匹配
    给你一个字符串 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));

    }
发布了49 篇原创文章 · 获赞 2 · 访问量 876

猜你喜欢

转载自blog.csdn.net/qq_43720551/article/details/104956710