日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

剑指Offer_52_正则表达式匹配

發布時間:2023/11/30 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 剑指Offer_52_正则表达式匹配 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目描述

請實現一個函數用來匹配包括'.'和''的正則表達式。模式中的字符'.'表示任意一個字符,而''表示它前面的字符可以出現任意次(包含0次)。 在本題中,匹配是指字符串的所有字符匹配整個模式。例如,字符串"aaa"與模式"a.a"和"ab*ac*a"匹配,但是與"aa.a"和"ab*a"均不匹配

解題思路

分情況討論:

  • 需要匹配的字符串和模式字符串都已經遍歷完成,那么就是匹配成功的。
  • 如果需要匹配的字符串沒有遍歷完,模式字符串已經匹配完,后面的字符串不能匹配,那么就是不匹配
  • 如果不是上面兩個情況,那么首先看一下模式串當前字符下一個字符是否是*,
    • 如果是,且當前需要匹配的字符和模式當前字符匹配(相同或者為.),那么就可以匹配下一個字符串(匹配字符串匹配下一個,模式字符串向后移動兩個),或者是下一個字符也使用當前模式,也可以是當前字符使用下一個模式來匹配。
      如果當前字符不匹配,那么就使用下一個模式匹配當前字符。
    • 如果模式字符下一個不是*,那么就看當前字符和當前模式是否匹配,如果匹配,那么就行判斷下一個字符和后面的模式是否匹配。否則就是不匹配的。

    實現

    public class Solution {public boolean match(char[] str, char[] pattern){if (str == null || pattern == null){return false;}return matchCore(str, pattern, 0, 0);}private boolean matchCore(char[] str, char[] pattern, int fIndex, int sIndex) {if (fIndex == str.length && sIndex == pattern.length){//已經匹配return true;}if (fIndex < str.length && sIndex == pattern.length){//匹配式已經沒有,但是字符串已經結束return false;}if (sIndex < pattern.length -1 && pattern[sIndex+1] == '*'){if (fIndex < str.length && (str[fIndex] == pattern[sIndex] || pattern[sIndex] == '.')){//當前這個x*匹配當前字符return matchCore(str,pattern,fIndex+1, sIndex) //后面的字符可以繼續用這個模式匹配|| matchCore(str,pattern,fIndex+1,sIndex+2) //當前的字符使用下一個模式匹配|| matchCore(str,pattern,fIndex,sIndex+2); //當前字符不使用當前模式匹配,使用后面的(因為*可以為匹配0次)}else {//當前這個x*不匹配當前字符,匹配模式向后移動到*后面//當字符串已經遍歷完成時,但是pattern 是".*a*"每個字符后面都是一個*時,也是匹配的return matchCore(str,pattern,fIndex,sIndex+2);}}//當前模式的后一個字符不是*,當字符串已經遍歷完成時,但是pattern 不是".*a*"形式的,不匹配if (fIndex < str.length && (str[fIndex] == pattern[sIndex] || pattern[sIndex] == '.')){//匹配當前字符return matchCore(str,pattern,fIndex+1,sIndex+1);}return false;} }

    轉載于:https://www.cnblogs.com/ggmfengyangdi/p/5812310.html

    總結

    以上是生活随笔為你收集整理的剑指Offer_52_正则表达式匹配的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。