题解 | #正则表达式匹配#

正则表达式匹配

http://www.nowcoder.com/practice/4332e089f39442568af33afac99345be

import java.util.*;
public class Main{
    public static void main(String[] args){
         Scanner in = new Scanner(System.in);
        String str=in.next();
        String pattern=in.next();
        System.out.println(match(str,pattern));
    }
    public static boolean match (String str, String pattern) {
        int n1 = str.length();
        int n2 = pattern.length();
        //dp[i][j]表示str前i个字符和pattern前j个字符是否匹配 fast-template
        boolean[][] dp = new boolean[n1 + 1][n2 + 1];
        //遍历str每个长度
        for (int i = 0; i <= n1; i++) {
            //遍历pattern每个长度
            for (int j = 0; j <= n2; j++) {
                //空正则的情况
                if (j == 0) {
                    dp[i][j] = (i == 0 ? true : false);
                    //非空的情况下 星号、点号、字符
                } else {
                    if (pattern.charAt(j - 1) != '*') {
                        //当前字符不为*,用.去匹配或者字符直接相同
                        if (i > 0 && (str.charAt(i - 1) == pattern.charAt(j - 1) ||
                                      pattern.charAt(j - 1) == '.')) {
                            dp[i][j] = dp[i - 1][j - 1];
                        }
                    } else {
                        //碰到*
                        if (j >= 2) {
                            dp[i][j] |= dp[i][j - 2];
                        }
                        //若是前一位为.或者前一位可以与这个数字匹配
                        if (i >= 1 && j >= 2 && (str.charAt(i - 1) == pattern.charAt(j - 2) ||
                                                 pattern.charAt(j - 2) == '.')) {
                            dp[i][j] |= dp[i - 1][j];
                        }
                    }
                }
            }
        }
        return dp[n1][n2];
    }
}
全部评论

相关推荐

11-04 19:05
已编辑
东莞城市学院 单片机
不知道怎么取名字_:你这个要实习两年?哪有这么久的,感觉就是即使你毕业了,但还按实习的话,是不是不用给你缴社保公积金啥的
点赞 评论 收藏
分享
评论
6
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务