首页 > 其他分享 >#yyds干货盘点# 动态规划专题:正则表达式匹配

#yyds干货盘点# 动态规划专题:正则表达式匹配

时间:2022-10-30 20:07:47浏览次数:64  
标签:yyds 匹配 charAt 字符 正则表达式 pattern 干货 str dp

1.简述:

描述

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

数据范围:

1.str 只包含从 a-z 的小写字母。

2.pattern 只包含从 a-z 的小写字母以及字符 . 和 *,无连续的 '*'。

3. #yyds干货盘点# 动态规划专题:正则表达式匹配_字符串4. #yyds干货盘点# 动态规划专题:正则表达式匹配_数据_02

输入描述:

第一行输入一个字符串 str。

第二行输入一个字符串 pattern。    

输出描述:

输出两个字符串的匹配结果,如果匹配则输出 true ,否则输出 false

示例1

输入:

aaa
a*a

输出:

true

示例2

输入:

aab
c*a*b

输出:

true

示例3

输入:

a
.*

输出:

true

示例4

输入:

aaab
a*a*a*c

输出:

false

2.代码实现:

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];
}
}

标签:yyds,匹配,charAt,字符,正则表达式,pattern,干货,str,dp
From: https://blog.51cto.com/u_15488507/5807774

相关文章

  • 正则表达式
    一、校验数字的表达式数字:[1]*$n位的数字:^\d{n}$至少n位的数字:^\d{n,}$m-n位的数字:^\d{m,n}$零和非零开头的数字:^(0|[1-9][0-9]*)$非零开头的最多带两位......
  • 正则表达式
    目录一、正则表达式前戏(python中要导入re模块才能使用)二、正则表达式内容介绍1、字符组2、特殊符号3、量词4、贪婪匹配与非贪婪匹配贪婪匹配非贪婪匹配5、转义符6、正则表......
  • 满满干货!成人高考各科目答题技巧,必看完!
    成考专升本考试除了公共科目外,还有一些专业科目,比如大学语文、高数、医学综合、教育理论等,你对于这些科目的复习够了解吗?首先答题攻略一定要牢记!答题总体要求:会做的要做......
  • #yyds干货盘点#Vue3.2 新指令 v-memo解析
    v-memo官方定义缓存一个模板的子树。在元素和组件上都可以使用。为了实现缓存,该指令需要传入一个固定长度的依赖值数组进行比较。如果数组里的每个值都与最后一次的渲染相......
  • #yyds干货盘点# LeetCode 腾讯精选练习 50 题:旋转链表
    题目:给你一个链表的头节点head,旋转链表,将链表每个节点向右移动 k 个位置。 示例1:输入:head=[1,2,3,4,5],k=2输出:[4,5,1,2,3]示例2:输入:head=[0,1,2],k=4输出......
  • #yyds干货盘点# LeetCode 腾讯精选练习 50 题:不同路径
    题目:一个机器人位于一个mxn 网格的左上角(起始点在下图中标记为“Start”)。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为“Finis......
  • #yyds干货盘点# 动态规划专题:滑雪
    1.简述:描述NowCoder喜欢滑雪,因为滑雪的确很刺激。为了获得速度,必须从高处往低处滑。现在知道某片区域的海拔,如下所示1 2 3 4516171819615242520714......
  • #yyds干货盘点# 动态规划专题:最长公共子序列(一)
    1.简述:描述给定两个字符串s1和s2,长度为n和m 。求两个字符串最长公共子序列的长度。所谓子序列,指一个字符串删掉部分字符(也可以不删)形成的字符串。例如:字符串"arcae......
  • 英雄联盟用什么语言编写?C/C++ yyds
    一直有读者咨询C/C++可以干什么,今天这篇文章分享一下具体应用领域。 1、操作系统MicrosoftWindows:汇编->C语言->C++Linux:C语言AppleMacOS: 主要为C语言,部......
  • JavaScript--正则表达式
    一、概述正则表达式(RegularExpression)是一个描述字符模式的对象,用于对字符串进行匹配,一般用在有规律的字符串匹配中;常用于表单验证以及相关的字符串匹配二、声明......