您当前的位置:首页 > 电脑百科 > 程序开发 > 算法

算法:正则表达式匹配

时间:2022-07-13 16:13:02  来源:  作者:做架构师不做框架师

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

示例1

  • 输入: s = "aa",p = "a"
  • 输出: false
  • 解释: "a" 无法匹配 "aa" 整个字符串。

示例2

  • 输入: s = "aaa",p = "ab*.*"
  • 输出: true
  • 解释: 因为 '*' 表示零个或多个,这里 'b' 为 0 个, '.' 为 a , 重复2次。因此可以匹配字符串 "aaa"。

提示

  • s 可能为空,且只包含从 a-z 的小写字母。
  • p 可能为空,且只包含从 a-z 的小写字母以及字符 . 和 *,无连续的 '*'。

方法:动态规划

算法:正则表达式匹配

 

以示例2为例讲解:

  • 初始化取 dp[0][0] = true,代表匹配成功;
  • 当s取“a”的时候:p取“a”时候,成功;
  • p取“ab”的时候,失败;
  • p取“ab*”时候,*出现 0 次,即为 p 取 “a” 时候,成功;
  • p取“ab*.”的时候,失败,因为 s 只有一个字母,“.” 可以是任意字母,不满足;
  • p取“ab*.*”的时候,“.” 出现 0 次,“b”出现 0 次,成功。
  • 以此类推……

 

代码如下:

算法:正则表达式匹配

 

复杂度分析

  • 时间复杂度:O(MN),其中 M,N 分别为 s 和 p 的长度,状态转移需遍历整个 dp 矩阵。
  • 空间复杂度:O(MN),状态矩阵 dp 使用 O(MN) 的额外空间。

END

本文内容出处是力扣官网,希望和大家一起刷算法,在后面的路上不变秃但是变强!



Tags:正则表达式   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
知道这些正则表达式,能让你少写1000行代码
校验密码强度 密码长度为8-16位 必须包含至少一个大写字母、一个小写字母和一个数字^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)[a-zA-Z\d]{8,16}$这个正则表达式的含义是: ^ 表示匹...【详细内容】
2023-11-30  Search: 正则表达式  点击:(163)  评论:(0)  加入收藏
Python正则表达式:高效处理文本数据的秘诀!
当谈到文本处理和搜索时,正则表达式是Python中一个强大且不可或缺的工具。正则表达式是一种用于搜索、匹配和处理文本的模式描述语言,可以在大量文本数据中快速而灵活地查找、...【详细内容】
2023-10-15  Search: 正则表达式  点击:(122)  评论:(0)  加入收藏
正则表达式进阶--玩转分组、前瞻和后顾
前言正则表达式是一种强大的模式匹配工具,可以用于在字符串中查找、替换和提取特定的文本。分组是一项非常重要的功能,它允许我们将模式进行分组,并在匹配过程中对分组进行操作...【详细内容】
2023-09-20  Search: 正则表达式  点击:(306)  评论:(0)  加入收藏
15 个常用的正则表达式技巧
你对正则表达式有何看法?我猜你会说这太晦涩难懂了,我对它根本不感兴趣。是的,我曾经和你一样,以为我这辈子都学不会了。但我们不能否认它确实很强大,我在工作中经常使用它,今天,我...【详细内容】
2023-09-05  Search: 正则表达式  点击:(273)  评论:(0)  加入收藏
20 个你应该掌握的强大而有用的正则表达式
一起来了解下20 个你应该掌握的强大而有用的正则表达式都有哪些。1.货币格式化我经常需要在工作中使用到格式化的货币,使用正则表达式让这变得非常简单。const formatPrice =...【详细内容】
2023-06-13  Search: 正则表达式  点击:(371)  评论:(0)  加入收藏
灾难性回溯:正则表达式如何导致ReDoS漏洞?
当用户需要搜索和替换文本时,正则表达式就会派上用场。然而,在某些情况下,它们可能会导致系统变慢,甚至容易受到ReDoS攻击。 ​简介​ReDoS是DoS攻击的一种子类型。ReDoS攻击的...【详细内容】
2023-03-28  Search: 正则表达式  点击:(193)  评论:(0)  加入收藏
正则表达式,这篇看完就够了
正则表达式是一种用于匹配文本模式的工具,它能够帮助我们在处理文本时更加高效地进行搜索、替换和验证操作。在本篇文章中,我将通过通俗易懂的语言让正则表达式不再苦涩难懂。...【详细内容】
2023-02-20  Search: 正则表达式  点击:(120)  评论:(0)  加入收藏
JavaScript正则表达式加密
JavaScript正则表达式加密正则表达式可以加密吗?是的,可以。起码可以确定的是在JavaScript编程中是可以的。正则表达式加密有什么用?可以隐藏一些重要的、私密的字符串内容,使代...【详细内容】
2022-11-27  Search: 正则表达式  点击:(285)  评论:(0)  加入收藏
Java正则表达式语法有哪些?
许多人在学习Java的过程中都会对Java正则表达式产生困惑,今天“好程序员”就将为大家解答如下问题:Java正则表达式是什么?Java正则表达式的规则有哪些?正则表达式语法有哪些?正则...【详细内容】
2022-11-01  Search: 正则表达式  点击:(339)  评论:(0)  加入收藏
算法:正则表达式匹配
请实现一个函数用来匹配包含'. '和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(含0次)。在本题...【详细内容】
2022-07-13  Search: 正则表达式  点击:(375)  评论:(0)  加入收藏
▌简易百科推荐
小红书、视频号、抖音流量算法解析,干货满满,值得一看!
咱们中国现在可不是一般的牛!网上的网友已经破了十个亿啦!到了这个互联网的新时代,谁有更多的人流量,谁就能赢得更多的掌声哦~抖音、小红书、、视频号,是很多品牌必争的流量洼地...【详细内容】
2024-02-23  二手车小胖说    Tags:流量算法   点击:(18)  评论:(0)  加入收藏
雪花算法详解与Java实现:分布式唯一ID生成原理
SnowFlake 算法,是 Twitter 开源的分布式 ID 生成算法。其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 ID。在分布式系统中的应用十分广泛,且 ID 引入了时间戳...【详细内容】
2024-02-03   一安未来  微信公众号  Tags:雪花算法   点击:(54)  评论:(0)  加入收藏
程序开发中常用的十种算法,你用过几种?
当编写程序时,了解和使用不同的算法对解决问题至关重要。以下是C#中常用的10种算法,每个算法都伴随着示例代码和详细说明。1. 冒泡排序 (Bubble Sort):冒泡排序是一种简单的比...【详细内容】
2024-01-17  架构师老卢  今日头条  Tags:算法   点击:(46)  评论:(0)  加入收藏
百度推荐排序技术的思考与实践
本文将分享百度在推荐排序方面的思考与实践。在整个工业界的推广搜场景上,特征设计通常都是采用离散化的设计,需要保证两方面的效果,一方面是记忆,另一方面是泛化。特征都是通过...【详细内容】
2024-01-09  DataFunTalk  微信公众号  Tags:百度推荐   点击:(81)  评论:(0)  加入收藏
什么是布隆过滤器?如何实现布隆过滤器?
以下我们介绍了什么是布隆过滤器?它的使用场景和执行流程,以及在 Redis 中它的使用,那么问题来了,在日常开发中,也就是在 Java 开发中,我们又将如何操作布隆过滤器呢?布隆过滤器(Blo...【详细内容】
2024-01-05  Java中文社群  微信公众号  Tags:布隆过滤器   点击:(94)  评论:(0)  加入收藏
面向推荐系统的深度强化学习算法研究与应用
随着互联网的快速发展,推荐系统在各个领域中扮演着重要的角色。传统的推荐算法在面对大规模、复杂的数据时存在一定的局限性。为了解决这一问题,深度强化学习算法应运而生。本...【详细内容】
2024-01-04  数码小风向    Tags:算法   点击:(106)  评论:(0)  加入收藏
非负矩阵分解算法:从非负数据中提取主题、特征等信息
非负矩阵分解算法(Non-negativeMatrixFactorization,简称NMF)是一种常用的数据分析和特征提取方法,主要用于从非负数据中提取主题、特征等有意义的信息。本文将介绍非负矩阵分解...【详细内容】
2024-01-02  毛晓峰    Tags:算法   点击:(75)  评论:(0)  加入收藏
再谈前端算法,你这回明白了吗?
楔子 -- 青蛙跳台阶一只青蛙一次可以跳上一级台阶,也可以跳上二级台阶,求该青蛙跳上一个n级的台阶总共需要多少种跳法。分析: 当n=1的时候,①只需要跳一次即可;只有一种跳法,即f(...【详细内容】
2023-12-28  前端爱好者  微信公众号  Tags:前端算法   点击:(114)  评论:(0)  加入收藏
三分钟学习二分查找
二分查找是一种在有序数组中查找元素的算法,通过不断将搜索区域分成两半来实现。你可能在日常生活中已经不知不觉地使用了大脑里的二分查找。最常见的例子是在字典中查找一个...【详细内容】
2023-12-22  小技术君  微信公众号  Tags:二分查找   点击:(81)  评论:(0)  加入收藏
强化学习算法在资源调度与优化中的应用
随着云计算和大数据技术的快速发展,资源调度与优化成为了现代计算系统中的重要问题。传统的资源调度算法往往基于静态规则或启发式方法,无法适应动态变化的环境和复杂的任务需...【详细内容】
2023-12-14  职场小达人欢晓    Tags:算法   点击:(169)  评论:(0)  加入收藏
站内最新
站内热门
站内头条