剑指 Offer 19. 正则表达式匹配

剑指 Offer 19. 正则表达式匹配

初始化要考虑主串为空字符串,模式串为 a*b*c* 的形式。

一般情况时,根据模式串是普通字符'.''*'分情况考虑。为'*'时,考虑匹配0次匹配多次的情况,匹配多次时要注意判断前提是能匹配。

java 复制代码
class Solution {
    public boolean isMatch(String s, String p) {
        int m = s.length(), n = p.length();
        boolean[][] dp = new boolean[m + 1][n + 1];
        dp[0][0] = true;
        for(int i = 2; i <= n; i += 2) {
            if(p.charAt(i - 1) == '*'){
                dp[0][i] = dp[0][i - 2];
            }
        }

        for(int i = 1; i <= m; i++){
            for(int j = 1; j <= n; j++){
                if(p.charAt(j - 1) == s.charAt(i - 1)){
                    dp[i][j] = dp[i - 1][j - 1];
                }else if(p.charAt(j - 1) == '.'){
                    dp[i][j] = dp[i - 1][j - 1];
                }else if(p.charAt(j - 1) == '*'){
                    dp[i][j] = dp[i][j - 2];  // 匹配0次
                    if(p.charAt(j - 2) == s.charAt(i - 1) ||  p.charAt(j - 2) == '.') dp[i][j] |= dp[i - 1][j];  // 匹配多次
                }
            }
        }

        return dp[m][n];
    }
}
相关推荐
liujing1023292931 分钟前
Day09_刷题niuke20250609
java·c++·算法
不7夜宵34 分钟前
力扣热题100 k个一组反转链表题解
算法·leetcode·链表
蒟蒻小袁2 小时前
力扣面试150题--课程表
算法·leetcode·面试
闻缺陷则喜何志丹2 小时前
【动态规划】B4336 [中山市赛 2023] 永别|普及+
c++·算法·动态规划·洛谷
不二狗3 小时前
每日算法 -【Swift 算法】电话号码字母组合
开发语言·算法·swift
AL流云。3 小时前
【优选算法】分治
数据结构·算法·leetcode·排序算法
C++ 老炮儿的技术栈8 小时前
UDP 与 TCP 的区别是什么?
开发语言·c++·windows·算法·visual studio
殇者知忧8 小时前
【论文笔记】若干矿井粉尘检测算法概述
深度学习·神经网络·算法·随机森林·机器学习·支持向量机·计算机视觉
mochensage10 小时前
C++信息学竞赛中常用函数的一般用法
java·c++·算法
chengooooooo10 小时前
leetcode Top100 238. 除自身以外数组的乘积|数组系列
算法·leetcode