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

正则表达式匹配_正则表达式匹配字符串长度题目描述请实现一个函数用来匹配包括'.'和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

题目描述

请实现一个函数用来匹配包括’.’和’*’的正则表达式。模式中的字符’.’表示任意一个字符,而’*’表示它前面的字符可以出现任意次(包含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.net/167492.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月2日 上午6:00
下一篇 2022年8月2日 上午6:00


相关推荐

  • Vue分页导航_vue分页组件

    Vue分页导航_vue分页组件Vue分页导航原文链接:https://www.cnblogs.com/vivaxiaonan/p/9987985.html这里我用的是脚手架,粘Viva_nan大佬的代码封装了一个.vue组件。实现效果如下:封装组件newCom.vue代码:<template><divclass=”wrapper”><navclass=”zpagenav”><ulclass=”page-ul”>…

    2026年4月17日
    4
  • expect用法介绍

    expect用法介绍一、概念Expect是一个用来实现自动交互功能的软件套件。执行shell脚本,需要从终端得到输入时(如sshroot@192.168.1.2),Expect可以根据提示,模拟标准输入来实现交互脚本执行,使其以非交互的方式执行可以把shell和expect理解为两种不同的脚本语言,expect有独自的语法、变量二、ssh远程主机的方式2.1.简单方式,直接使用expect命令#!/bin/bash#登陆远程主机并查看主机名IP=”192.168.1.2″USERNAME=”root”P

    2025年8月23日
    2
  • VAE(Variational Autoencoder)的原理「建议收藏」

    VAE(Variational Autoencoder)的原理「建议收藏」Kingma,DiederikP.,andMaxWelling."Auto-encodingvariationalbayes." arXivprepri

    2022年7月3日
    25
  • sql中declare的用法_sql局部变量

    sql中declare的用法_sql局部变量换工作了,以后主要和SqlServer打交道了,仿佛回到了大学,不知道学校的饭还是那么好吃又便宜吗?北京的饭好贵;不知道门口哪家板面的生意是不是还是那么红火,好想再去吃一碗。。。咳咳,不多说了,直接进入主题declare这个类型,其实可以理解为Java里面的public类型变量,全局有效,当然非要较真的话,我觉得归到protected类也可以(不理解的话不要看后半段,只是为了严谨)Java修饰符 public:对所有类可见。使用对象:类、接口、变量、方法 protect..

    2022年8月20日
    10
  • 使用DatagramSocket发送、接收数据(Socket之UDP套接字)

    使用DatagramSocket发送、接收数据(Socket之UDP套接字)http://book.51cto.com/art/201203/322540.htm17.4.2使用DatagramSocket发送、接收数据(1)Java使用DatagramSocket代表UDP协议的Socket,DatagramSocket本身只是码头,不维护状态,不能产生IO流,它的唯一作用就是接收和发送数据报,Java使用DatagramPacket来代表数据报,Datagr

    2022年6月12日
    95
  • Electron 入门_electron爬虫

    Electron 入门_electron爬虫前言前端开发桌面程序这个概念已经出现有一段时间了,这项技术也已经走向成熟,Github上nw和光electron的star就差不多有10w颗星了,github也衍生出了很多开源的桌面项目俨然成了一个

    2022年8月5日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号