leetcode正则表达式匹配问题(困难)

1.题目描述

2.解题思路,这道题自己没做出来,看了官方的题解,感觉对自己来说确实是比较难想的。使用了动态规划的解决方案,这种方案看题解都不一定能看明白,不过有个评论画图讲解的非常明白。其实仔细看题解的话,会发现和之前做的最长回文差不多。也先是定义了一个二维数组,f[i][j],用来描述是否是字符串s中的前i个字符和匹配串中的前J个是否相同。这个相同的条件又取决于之前的数组的真真假假,从这里我们就能看出这是可以分解成为一个子问题的动态规划问题。这里附上官方的题解。我精简了一下。本人学习记录,如有侵权,联系作者删除。

不妨换个角度思考问题,字母+*代表的情况如下:

3.解题代码(官方题解)

python 复制代码
class Solution:
    def isMatch(self, s: str, p: str) -> bool:
        m, n = len(s), len(p)

        def matches(i: int, j: int) -> bool:
            if i == 0:
                return False
            if p[j - 1] == '.':
                return True
            return s[i - 1] == p[j - 1]

        f = [[False] * (n + 1) for _ in range(m + 1)]
        f[0][0] = True
        for i in range(m + 1):
            for j in range(1, n + 1):
                if p[j - 1] == '*':
                    f[i][j] |= f[i][j - 2]
                    if matches(i, j - 1):
                        f[i][j] |= f[i - 1][j]
                else:
                    if matches(i, j):
                        f[i][j] |= f[i - 1][j - 1]
        return f[m][n]

学习记录用,有问题可以一块探讨。

相关推荐
tt55555555555511 分钟前
每日一题——滑动窗口的最大值
c语言·数据结构·算法·leetcode·八股文
眼镜哥(with glasses)30 分钟前
蓝桥杯python基础算法(2-2)——基础算法(D)——进制转换*
算法
和风化雨43 分钟前
排序算法--选择排序
c语言·c++·算法·排序算法
和风化雨1 小时前
排序算法--桶排序
c语言·数据结构·c++·算法·排序算法
龙之竹2 小时前
2025职业发展规划
职场和发展
董董灿是个攻城狮2 小时前
DeepSeek-R1 技术报告精华整理:通过强化学习提升大模型推理能力
算法
小姚也要变强2 小时前
sort排序 计数排序 map set C++ 蓝桥杯
开发语言·c++·算法·蓝桥杯
WBluuue2 小时前
大一计算机的自学总结:数据结构设计相关题
数据结构·c++·算法·leetcode·链表
白白糖2 小时前
Day 28 卡玛笔记
python·算法·力扣
JNU freshman2 小时前
蓝桥杯思维训练营(四)
算法·蓝桥杯