zl程序教程

您现在的位置是:首页 >  前端

当前栏目

正则表达式匹配_正则表达式匹配字符串长度

正则表达式 字符串 长度 匹配
2023-06-13 09:12:57 时间

大家好,又见面了,我是你们的朋友全栈君。

题目描述

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

提交链接: 点击

思路: 分两种情况讨论

1.第2个字符不为*时

1.1 当前主串字符和模式串字符匹配,那么主串和模式串指针相应往后移一位,接着递归进行匹配

(匹配有两种情况,一种是直接相等;另一种是模式串为.且主串不为空)

    1.2 当前主串字符和模式串字符不匹配,那么直接返回false

  2.第2个字符为*时

2.1 当前主串字符和模式串字符匹配,那么分为三种情况:

      2.1.1 *取值为0, 主串指针不动,模式串指针+2

      2.1.2 *取值为1, 主串指针+1,模式串指针+2

      2.1.3 *取值为多,主串指针+1,模式串指针不动

      (其中2.1.2可由 先2.1.3再2.1.1得到,因此下面代码红色阴影部分可不写,提升算法速度!)

    2.2 当前主串字符和模式串字符不匹配,那么就是*直接取值为0,模式串指针+2跟接下来的字符进行匹配,表示跳过此字符。

代码:

class Solution { public: bool match(char* str, char* pattern) { if(str[0]=='\0' && pattern[0]=='\0'){ return true; }else if(str[0]!='\0' && pattern[0] =='\0'){ return false; } if(pattern[1]!='*'){ //第2个字符不为* if(str[0]==pattern[0]||(pattern[0]=='.' && str[0]!='\0')){ //字符匹配 return match(str+1,pattern+1); }else{ //字符不匹配 return false; } }else{ //第2个字符为* if(str[0]==pattern[0]||(pattern[0]=='.' && str[0]!='\0')) //字符匹配 return match(str,pattern+2) || match(str+1,pattern+2) || match(str+1,pattern); else return match(str,pattern+2); //字符不匹配  } } };

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/167492.html原文链接:https://javaforall.cn