剑指offer系列之五十一:正则表达式匹配

2024-05-30 16:58

本文主要是介绍剑指offer系列之五十一:正则表达式匹配,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

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

由于只涉及两种正则表达式的匹配,所以关键是需要分清除匹配的所有情况,对于模式串来讲,出现了’.’和’*’的时候需要单独考虑,因为两者的匹配情况是不一样的。先考虑模式串中有’*’的情况,因为’*’可以匹配0个或者多个,所以如果模式串的下一个字符是’*’的时候就有三种情况:1)匹配0个主串的字符,比如主串是abc,模式串是b*的时候,就是这种情况,那么下一步的匹配策略是主串保持不变,模式串跳到下两个字符重新比较;2)匹配1个字符,比如主串是abc,模式串是a*就是这种情况,因为只匹配到了a这一个字符。这种情况的下一步的比较策略应该是主串跳到下一个字符,模式串移动两个位置;3)匹配多个字符,比如主串是aac,模式串是a*cb就匹配到了aa这两个字符,那么这种情况下下一步的匹配策略应该是主串移动一个字符,模式串移动两个位置;如果当前的字符与主串的字符不能匹配,则主串保持不变,模式串移动两个位置。如果当前字符是’.’的话,直接逐个字符进行比较就行了。下面是这种思路的实现代码(已被牛客AC):

package com.rhwayfun.offer;public class MatchRegString {public boolean match(char[] str, char[] pattern) {if (str == null || pattern == null)return false;return matchRegCore(str, 0, str.length, pattern, 0, pattern.length);}private boolean matchRegCore(char[] str, int i, int length1,char[] pattern, int j, int length2) {if (i == length1 && j == length2) {// 主串匹配到末尾,模式串要么也匹配到末尾要么当前位置的字符是*,否则返回falseif (j == length2 || pattern[j] == '*')return true;elsereturn false;}if (i != length1 && j == length2)return false;/** 一、如果模式串的下一个字符是*, 1.1 并且模式串的当前字符能与主串的字符进行匹配,则可能出现三种情况:* 1、模式串的当前字符匹配到0个字符,则主串不变,模式穿移动到两个字符* 2、模式穿的当前字符匹配到1个字符,则主串移动一个位置,模式串移动两个位置* 3、模式串的当前字符匹配到多个字符,则主串移动一个位置,模式串移动两个位置。 1.2 如果不能匹配的话: 主串不变,模式串移动两个位置;* 二、如果下一个字符不是*,则进行逐个字符进行匹配 三、如果模式串的下一个字符是.,则就进行一个字符的匹配*/if (j + 1 < length2 && pattern[j + 1] == '*') {if (i < length1 && (pattern[j] == str[i] || pattern[j] == '.')) {return matchRegCore(str, i + 1, length1, pattern, j, length2)|| matchRegCore(str, i + 1, length1, pattern, j + 2,length2)|| matchRegCore(str, i, length1, pattern, j + 2,length2);} else {return matchRegCore(str, i, length1, pattern, j + 2, length2);}}if (i < length1 && (str[i] == pattern[j] || pattern[j] == '.')) {return matchRegCore(str, i + 1, length1, pattern, j + 1, length2);}return false;}public static void main(String[] args) {char[] str = { 'a', 'a', 'a' };char[] pattern = { 'a', 'b', '*', 'a' };boolean b = new MatchRegString().match(str, pattern);System.out.println(b);}
}

这篇关于剑指offer系列之五十一:正则表达式匹配的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1016572

相关文章

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

SpringBoot3匹配Mybatis3的错误与解决方案

《SpringBoot3匹配Mybatis3的错误与解决方案》文章指出SpringBoot3与MyBatis3兼容性问题,因未更新MyBatis-Plus依赖至SpringBoot3专用坐标,导致类冲... 目录SpringBoot3匹配MyBATis3的错误与解决mybatis在SpringBoot3如果

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

正则表达式r前缀使用指南及如何避免常见错误

《正则表达式r前缀使用指南及如何避免常见错误》正则表达式是处理字符串的强大工具,但它常常伴随着转义字符的复杂性,本文将简洁地讲解r的作用、基本原理,以及如何在实际代码中避免常见错误,感兴趣的朋友一... 目录1. 字符串的双重翻译困境2. 为什么需要 r?3. 常见错误和正确用法4. Unicode 转换的

Nginx路由匹配规则及优先级详解

《Nginx路由匹配规则及优先级详解》Nginx作为一个高性能的Web服务器和反向代理服务器,广泛用于负载均衡、请求转发等场景,在配置Nginx时,路由匹配规则是非常重要的概念,本文将详细介绍Ngin... 目录引言一、 Nginx的路由匹配规则概述二、 Nginx的路由匹配规则类型2.1 精确匹配(=)2

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中

Nginx location匹配模式与规则详解

《Nginxlocation匹配模式与规则详解》:本文主要介绍Nginxlocation匹配模式与规则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、环境二、匹配模式1. 精准模式2. 前缀模式(不继续匹配正则)3. 前缀模式(继续匹配正则)4. 正则模式(大