正则表达式匹配

第五十一题:正则表达式匹配

    • 题目描述
    • 思路
          • 先看 * 再看 匹配
          • 先看匹配 ,再看 *


题目描述

请实现一个函数用来匹配包括’.‘和’‘的正则表达式。模式中的字符’.‘表示任意一个字符,而’'表示它前面的字符可以出现任意次(包含0次)。
在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"abaca"匹配,但是与"aa.a"和"ab*a"均不匹配


思路

①先看 * 再看 匹配
前提:当pattern遍历完,return取决于str是否遍历完,str恰好遍历完才返回true,再接下来讨论
1.若当前字符存在下一个字符,看下一个字符是否是 ‘’,如果是,有2种情况
一:当前匹配
1.1match(str,i + 1,pattern,j)//跳过str
1.2match(str,i,pattern,j + 2)//跳过pattern
1.3match(str,i + 1,pattern,j + 2)//这一种可以省略,相当于 1.1 + 1.2
二:当前不匹配
match(str,i,pattern,j + 2)//跳过pattern
2.下一个不是 *
当前匹配 return match(str,i + 1,pattern,j + 1)
②反过来,先看匹配 ,再看 *
前提:当pattern遍历完,return取决于str是否遍历完,再接下来讨论
1.先看当前字符是否匹配 记录first_isMatch
2.再看下一个字符是否为 '

2.1当前匹配first_isMatch && match(str,i + 1,pattern,j)
2.2无论匹配与否match(str,i,pattern,j + 2)//跳过
3.不匹配*,当前字符匹配的前提下,进入到下一个循环
else first_isMatch && match(str,i + 1,pattern,j + 1)


先看 * 再看 匹配
private  boolean match(char[] str, int i, char[] pattern, int j) {
    //pattern遍历完了
    if(j == pattern.length){
        //如果str也完了,返回true,不然false
        return str.length == i;
    }
    //注意数组越界问题,一下情况都保证数组不越界
    if(j < pattern.length - 1 && pattern[j + 1] == '*') {//下一个是*
        if(str.length != i && //当前匹配
                (str[i] == pattern[j] || pattern[j] == '.')) //匹配
            return match(str,i,pattern,j + 2)
                    || match(str,i + 1,pattern,j);
        else//当前不匹配
            return match(str,i,pattern,j + 2);
    }
    //下一个不是“*”,当前匹配
    if(str.length != i && (str[i] == pattern[j] || pattern[j] == '.'))
        return match(str,i + 1,pattern,j + 1);
    return false;
}

先看匹配 ,再看 *
private boolean match1(char[] str, int i, char[] pattern, int j) {
    if(j == pattern.length)//pattern遍历完了
        return str.length == i;//如果str也完了,返回true,不然false
    //1.先看当前是否匹配
    boolean first_isMatch = (i != str.length) && (str[i] == pattern[j] || pattern[j] == '.');
    //2.再看后面是否有* pattern[j + 1] == '*'
    if(j < pattern.length - 1 && pattern[j + 1] == '*') {
        return match1(str, i, pattern, j + 2) ||
                (first_isMatch && match1(str, i + 1, pattern, j));
    }else {
        return first_isMatch && match1(str, i + 1, pattern, j + 1);
    }
}

NowCoder(Online Coding, Please Click)

你可能感兴趣的:(剑指offer)