LeetCode-10 正则表达式匹配

LeetCode-10 正则表达式匹配

动态规划

10. 正则表达式匹配

dp数组含义dp[i][j]dp[i][j]dp[i][j] 表示 s[0:i−1]s[0:i-1]s[0:i1] 能否被 p[0:j−1]p[0:j-1]p[0:j1] 成功匹配。

状态转移方程

  • 如果 s[i−1]==p[j−1]s[i-1]==p[j-1]s[i1]==p[j1] ,那么当前字符是匹配成功了,整个子串是否匹配成功取决于之前的子串能否匹配,即 dp[i][j]=d[i−1][j−1]dp[i][j]=d[i-1][j-1]dp[i][j]=d[i1][j1]
  • 如果 s[i−1]≠p[j−1]s[i-1]\ne p[j-1]s[i1]=p[j1] ,可以按 p[j−1]p[j-1]p[j1] 是什么分三种情况:
    • 如果 p[j−1]p[j-1]p[j1].* 之外的字符,那肯定不匹配了,dp[i][j]=falsedp[i][j]=falsedp[i][j]=false
    • 如果 p[j−1]==′.′p[j-1]=='.'p[j1]==. ,由于 . 可以匹配任何字符,因此当前字符也肯定匹配成功了,还是取决于之前的子串,即 dp[i][j]=dp[i−1][j−1]dp[i][j]=dp[i-1][j-1]dp[i][j]=dp[i1][j1]
    • 如果 p[j−1]==′∗′p[j-1]=='*'p[j1]== ,情况比较复杂,需要再看 p[j−2]p[j-2]p[j2]s[i−1]s[i-1]s[i1] 的关系,因为 p[j−2]p[j-2]p[j2] 要与 s[i−1]s[i-1]s[i1] 匹配上,p[j−1]p[j-1]p[j1] 的这个 * 才有用
      • 而所谓 ”匹配上“,可能有两种情况,一个是字符相同,即 p[j−2]=s[i−1]p[j-2]=s[i-1]p[j2]=s[i1];另一个是 p[j−2]p[j-2]p[j2]. ,匹配任意字符。可以再按照 p[j−1]p[j-1]p[j1] 这个 *s[i−1]s[i-1]s[i1] 这个字符出现几次来分,零次、一次或两次及以上:
        • p[j−1]p[j-1]p[j1] 匹配零个 sss 中字符,相当于删掉 * 自己及其之前的一个字符,看能不能匹配成功,比如 ### 和 ###a* ,这时 dp[i][j]=dp[i][j−2]dp[i][j]=dp[i][j-2]dp[i][j]=dp[i][j2]
        • p[j−1]p[j-1]p[j1] 匹配一个 sss 中字符,相当于把 * 自己删掉,看能不能匹配成功,比如 ### 和 ###*,这时 dp[i][j]=dp[i−1][j−2]dp[i][j]=dp[i-1][j-2]dp[i][j]=dp[i1][j2]
        • p[j−1]p[j-1]p[j1] 匹配多个 sss 中字符,这时 dp[i][j]=dp[i−1][j]dp[i][j]=dp[i-1][j]dp[i][j]=dp[i1][j]
        • 注意,以上三种情况只要满足一种即可,是 的关系。
      • 如果未能匹配上,即 $p[j-2]\ne s[i-1] $ 且 p[j−2]≠′.′p[j-2]\ne '.'p[j2]=. ,这时 p[j−1]p[j-1]p[j1] 的这个 * 可以把没能匹配上的 p[j−2]p[j-2]p[j2] 删掉,因此就取决于再之前的子串是否匹配:dp[i][j]=dp[i][j−2]dp[i][j]=dp[i][j-2]dp[i][j]=dp[i][j2]

初始化

首先 dp[0][0]dp[0][0]dp[0][0]sssppp 均为空时, 认为是可以匹配的,之后的 dp[0][j]dp[0][j]dp[0][j] 要先看 p[j−1]p[j-1]p[j1] 是否为 * ,若为 * ,则 dp[0][j]=dp[0][j−2]dp[0][j]=dp[0][j-2]dp[0][j]=dp[0][j2]

其他位置均初始化为 falsefalsefalse

遍历顺序

从前到后即可

class Solution {
public:bool isMatch(string s, string p) {int m = s.size(), n = p.size();vector<vector<bool>> dp(m+1, vector<bool> (n+1, false));dp[0][0] = true;for (int j=1; j<n+1; ++j) {if (p[j-1] == '*') dp[0][j] = dp[0][j-2];}for (int i=1; i<m+1; ++i) {for (int j=1; j<n+1; ++j) {if (s[i-1] == p[j-1] || p[j-1] == '.') dp[i][j] = dp[i-1][j-1];else if (p[j-1] == '*') {if (s[i-1] == p[j-2] || p[j-2] == '.') {dp[i][j] = dp[i][j-2] || dp[i-1][j-2] || dp[i-1][j];}else {dp[i][j] = dp[i][j-2];}}}}return dp[m][n];}
};

Ref:

https://leetcode.cn/problems/regular-expression-matching/solution/shou-hui-tu-jie-wo-tai-nan-liao-by-hyj8/

https://leetcode.cn/problems/regular-expression-matching/solution/dong-tai-gui-hua-zen-yao-cong-0kai-shi-si-kao-da-b/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/532476.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

shell if判断和for循环常见写法

shell if判断和for循环常见写法 转自&#xff1a; Shell中for循环的几个常用写法 Shell中if 条件判断总结 if常见写法 一、if的基本语法: if [ command ];then符合该条件执行的语句 elif [ command ];then符合该条件执行的语句 else符合该条件执行的语句 fibash shell会按顺序…

关于pytorch使用多个dataloader并使用zip和cycle来进行循环时出现的显存泄漏的问题

关于pytorch使用多个dataloader并使用zip和cycle来进行循环时出现的显存泄漏的问题 如果我们想要在 Pytorch 中同时迭代两个 dataloader 来处理数据&#xff0c;会有两种情况&#xff1a;一是我们按照较短的 dataloader 来迭代&#xff0c;长的 dataloader 超过的部分就丢弃掉…

neovim及coc.nvim自动补全初探

neovim及coc.nvim自动补全初探 安装 # mac # 安装 brew install neovim # 查看neovim安装路径 brew list nvim# ubuntu apt install neovim习惯了打开 vi/vim 的方式&#xff0c;可以用个 alias 在 ~/.zshrc 中设置一下&#xff1a; alias vi"nvim"插件 vim-plug…

sed 简明教程

sed 简明教程 转自&#xff1a;https://coolshell.cn/articles/9104.html awk于1977年出生&#xff0c;今年36岁本命年&#xff0c;sed比awk大2-3岁&#xff0c;awk就像林妹妹&#xff0c;sed就是宝玉哥哥了。所以 林妹妹跳了个Topless&#xff0c;他的哥哥sed坐不住了&#xf…

awk 简明教程

awk 简明教程 转自&#xff1a;https://coolshell.cn/articles/9070.html 有一些网友看了前两天的《Linux下应该知道的技巧》希望我能教教他们用awk和sed&#xff0c;所以&#xff0c;出现了这篇文章。我估计这些80后的年轻朋友可能对awk/sed这类上古神器有点陌生了&#xff0c…

应该知道的LINUX技巧

应该知道的LINUX技巧 转自&#xff1a;https://coolshell.cn/articles/8883.html 这篇文章来源于Quroa的一个问答《What are some time-saving tips that every Linux user should know?》—— Linux用户有哪些应该知道的提高效率的技巧。我觉得挺好的&#xff0c;总结得比较好…

[深度][PyTorch] DDP系列第一篇:入门教程

[深度][PyTorch] DDP系列第一篇&#xff1a;入门教程 转自&#xff1a;[原创][深度][PyTorch] DDP系列第一篇&#xff1a;入门教程 概览 想要让你的PyTorch神经网络在多卡环境上跑得又快又好&#xff1f;那你definitely需要这一篇&#xff01; No one knows DDP better than I…

[深度][PyTorch] DDP系列第二篇:实现原理与源代码解析

[深度][PyTorch] DDP系列第二篇&#xff1a;实现原理与源代码解析 转自&#xff1a;https://zhuanlan.zhihu.com/p/187610959 概览 想要让你的PyTorch神经网络在多卡环境上跑得又快又好&#xff1f;那你definitely需要这一篇&#xff01; No one knows DDP better than I do! …

[深度][PyTorch] DDP系列第三篇:实战与技巧

[深度][PyTorch] DDP系列第三篇&#xff1a;实战与技巧 转自&#xff1a;https://zhuanlan.zhihu.com/p/250471767 零. 概览 想要让你的PyTorch神经网络在多卡环境上跑得又快又好&#xff1f;那你definitely需要这一篇&#xff01; No one knows DDP better than I do! – – …

PIL、OpenCV中resize算子实现不同的问题

PIL、OpenCV中resize算子实现不同的问题 测试图像&#xff1a;https://raw.githubusercontent.com/TropComplique/ssd-pytorch/master/images/dogs-and-cats.jpg &#xff08;直接 wget 可获得&#xff09; 测试版本&#xff1a; opencv-python 4.4.0.46Pillow 8.0.1 测试代…

mac X11 XQuartz的安装与使用

mac X11 XQuartz的安装与使用 本地系统&#xff1a;MacOS 12.4 远程主机系统&#xff1a;Ubuntu 18.04 命令说明 ssh命令 ssh 命令大家很熟悉了&#xff0c;这里仅介绍与 X11 forwarding 相关的几个选项。 本部分译自 ssh 命令手册&#xff0c;可见 man ssh -X &#xf…

机器学习:系统设计与实现 分布式训练

机器学习系统:设计与实现 分布式训练 转自&#xff1a;https://openmlsys.github.io/chapter_distributed_training/index.html 随着机器学习的进一步发展&#xff0c;科学家们设计出更大型&#xff0c;更多功能的机器学习模型&#xff08;例如说&#xff0c;GPT-3&#xff09;…

Linux命令行及各常用工具代理设置

Linux命令行及各常用工具代理设置 命令行代理设置 1 通过命令行指定 直接为当前命令行设置代理 对当前终端的全部工具&#xff08;apt、curl、wget、git 等全都有效&#xff09;以下仅以 http 代理为例&#xff0c;如果是其他协议&#xff08;如 socks 等&#xff09;自行改…

VimScript 五分钟入门(翻译)

VimScript 五分钟入门&#xff08;翻译&#xff09; 转自&#xff1a;https://zhuanlan.zhihu.com/p/37352209 译注&#xff1a;折腾 Vim 当然要能看懂和改写相关脚本&#xff0c;而中文资料匮乏&#xff0c;缺一个提纲挈领的教程。本文翻译自 Andrew Scala 的 《Five Minute V…

C++多线程推理、生产者消费者模式封装

C多线程推理、生产者消费者模式封装 tensorRT从零起步迈向高性能工业级部署&#xff08;就业导向&#xff09; 课程笔记&#xff0c;讲师讲的不错&#xff0c;可以去看原视频支持下。 深度学习推理中的多线程知识概览 本章介绍的多线程主要是指算法部署时所涉及的多线程内容&a…

在Python中调用C/C++:cython及pybind11

在Python中调用C/C&#xff1a;cython及pybind11 转自&#xff1a;https://zhuanlan.zhihu.com/p/442935082 Python写起来非常方便, 但面对大量for循环的时候, 执行速度有些捉急. 原因在于, python是一种动态类型语言, 在运行期间才去做数据类型检查, 这样效率就很低(尤其是大规…

Pytorch导出onnx模型,C++转化为TensorRT并实现推理过程

Pytorch导出onnx模型&#xff0c;C转化为TensorRT并实现推理过程 前言 本文为旨在实现整个Python导出PyTorch模型&#xff0c;C转化为TensorRT并实现推理过程过程&#xff0c;只与模型推理&#xff0c;模型部署相关&#xff0c;不涉及模型训练。为突出整个部署过程而非具体模…

从零Makefile落地算法大项目,完整案例教程

从零Makefile落地算法大项目&#xff0c;完整案例教程 转自&#xff1a;从零Makefile落地算法大项目&#xff0c;完整案例教程 作者&#xff1a;手写AI 前言 在这里&#xff0c;你能学到基于Makefile的正式大项目的使用方式和考虑&#xff0c;相信我&#xff0c;其实可以很简单…

PyTorch扩展自定义PyThonC++(CUDA)算子的若干方法总结

PyTorch扩展自定义PyThon/C(CUDA)算子的若干方法总结 转自&#xff1a;https://zhuanlan.zhihu.com/p/158643792 作者&#xff1a;奔腾的黑猫 在做毕设的时候需要实现一个PyTorch原生代码中没有的并行算子&#xff0c;所以用到了这部分的知识&#xff0c;再不总结就要忘光了 &a…

给 Python 算法插上性能的翅膀——pybind11 落地实践

给 Python 算法插上性能的翅膀——pybind11 落地实践 转自&#xff1a;https://zhuanlan.zhihu.com/p/444805518 作者&#xff1a;jesonxiang&#xff08;向乾彪&#xff09;&#xff0c;腾讯 TEG 后台开发工程师 1. 背景 目前 AI 算法开发特别是训练基本都以 Python 为主&…