【劍指offer】_17正則表達式的匹配

題目描述

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

解題思路

就是分兩種情況,看表達式的下一個字符是不是'*'

  1. pattern下一個字符不為‘*’:這種情況比較簡單,直接匹配當前字符。如果
    匹配成功,繼續匹配下一個;如果匹配失敗,直接返回false。注意這里的
    “匹配成功”,除了兩個字符相同的情況外,還有一種情況,就是pattern的
    當前字符為‘.’,同時str的當前字符不為‘\0’。
  2. pattern下一個字符為‘*’時,稍微復雜一些,因為‘*’可以代表0個或多個。
    這里把這些情況都考慮到:
    • ‘*’匹配0個字符時,str當前字符不變,pattern當前字符后移兩位,
      跳過這個‘*’符號;
    • ‘*’匹配1個或多個時,str當前字符移向下一個,pattern當前字符
      不變。(這里匹配1個或多個可以看成一種情況,因為:當匹配一個時,
      由于str移到了下一個字符,而pattern字符不變,就回到了上邊的情況a;
      當匹配多于一個字符時,相當于從str的下一個字符繼續開始匹配)

代碼實現

class Solution {
public:bool match(char* str, char* pattern){if(*str == '\0'&& *pattern == '\0')return true;if(*str != '\0' && *pattern == '\0')return false;//如果表達式的下一個字符不是*//正常處理//判斷當前是否相等或者只要表達式為.并且匹配的字符串不為空//然后返回str+,pattern+1判斷下一個if(*(pattern+1) != '*'){if(*str == *pattern || *str != '\0'&& *pattern == '.')return match(str+1,pattern+1);elsereturn false;}//否則下一個字符為'*'else{if(*str == *pattern || *str!= '\0' && *pattern == '.')return match(str,pattern+2)|| match(str+1,pattern);elsereturn match(str,pattern+2);}}
};

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/383087.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/383087.shtml
英文地址,請注明出處:http://en.pswp.cn/news/383087.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

大四階段的社會實踐的主要目的是_疫情當前,大三大四的學生“很慘”?大一大二的學生也別松懈...

大四畢業生不容易這次疫情對于高校學生而言,可以說是各有各的難處,“這屆畢業生很慘”更是屢上熱搜。不可否認,大四畢業生確實很不容易,論文答辯、畢業、求職就業等都受到了影響,雖然有困難,但各方都在積極…

【劍指offer】_18 數據流中的中位數

題目描述 如何得到一個數據流中的中位數?如果從數據流中讀出奇數個數值,那么中位數就是所有數值排序之后位于中間的數值。如果從數據流中讀出偶數個數值,那么中位數就是所有數值排序之后中間兩個數的平均值。我們使用Insert()方法讀取數據流…

【劍指offer】_19 滑動窗口中的最大值

題目描述 給定一個數組和滑動窗口的大小,找出所有滑動窗口里數值的最大值。例如,如果輸入數組{2,3,4,2,6,2,5,1}及滑動窗口的大小3,那么一共存在6個滑動窗口,他們的最大值分別為{4,4,6,6,6,5}; 針對數組{2,3,4,2,6,2,…

android 文字反轉_多文字共享信息系統

歐陽貴林 www.HeZi.net首發表于2016年03月23日“ 處在信息時代的開端,信息技術不應有特殊的文字性,需要創建多文字共享信息系統,給各國文字一個公平的參與信息與科技創新發展的平臺。這是世界的事,更是中國事。”01人類語言語言文…

LeetCode【1--兩數之和】 LeetCode【2--兩數相加】

兩數之和 題目描述 給定一個整數數組 nums 和一個目標值 target,請你在該數組中找出和為目標值的那 兩個 整數,并返回他們的數組下標。 你可以假設每種輸入只會對應一個答案。但是,你不能重復利用這個數組中同樣的元素。 解題思路 直接兩…

input數字開頭不能為0_李商隱為初戀寫詩,每句以數字開頭,最后10字一直被仿從未被超越...

上學時,每次寫作文,老師總愛在耳邊念叨:“你的作文得讓閱卷老師看得懂,不然不可能給你高分的!”每次聽到話,筆者總是用李商隱的詩來和他斗嘴。是的,李商隱的詩作常常是讓人讀不懂的,…

lsass.exe 當試圖更新密碼時_“驅動人生”下載器木馬再度更新-你應該注意什么?...

360安全大腦監測到通過"驅動人生"供應鏈攻擊傳播的挖礦木馬在1月30日下午4時左右再次更新。此次更新中,木馬在此前抓取系統帳戶密碼的基礎上增加了抓取密碼hash值的功能,并試圖通過pass the hash攻擊進行橫向滲透,使得該木馬的傳播…

LeetCode【3--無重復的最長字串】 LeetCode【4--有序數組中的中位數】

無重復的最長字串 題目描述 給定一個字符串,請你找出其中不含有重復字符的 最長子串 的長度。 解題思路 看到這道題,其實就兩個步驟,遍歷字符串,記錄當前字符有沒有重復。 重復一般解決就是哈希,這里用個數組表示…

hwt字體轉換ttf_五分鐘教你弄懂了字體反爬是個啥

今天的文章內容主要是關于字體反爬。目前已知的幾個字體反爬的網站是貓眼,汽車之家,天眼查,起點中文網等等。以前也看過這方面的文章,今天跟個老哥在交流的時候,終于實操了一把,弄懂了字體反爬是個啥玩意。…

LeetCode【5--最長的回文子串】 LeetCode【6--Z字形變換】

最長的回文子串 題目描述 給定一個字符串 s,找到 s 中最長的回文子串。你可以假設 s 的最大長度為 1000。 解題思路 可以跟無重復的最長子串一樣,用一個滑動窗口,只不過這個窗口的右邊界往右,左邊界每回要從右邊界的下標往左…

androidstudio 日歷視圖怎么顯示農歷_中秋國慶旅游攻略怎么做?用這個便簽軟件很簡單...

九月已經到來,中秋節和國慶節距離我們也不遠了,今年的中秋和國慶節重疊了有足足八天的假期。不少人都想趁著這個小長假出門旅游,要想保證旅游質量,那么就要做好攻略。中秋國慶旅游攻略怎么做?要想做好一份中秋國慶旅游…

c++ select函數_PySpark 操作函數一覽

PySpark 操作函數一覽Created: Sep 14, 2020 10:28 AM Tags: Big Data, PySpark, Python, SparkPyspark.sql.functionsfrom pyspark.sql import functions as F函數使用說明基本數學函數類abssin、cos、tan、asin、acos 、atan、sinh、cosh、tanhceil、round、floorexp、log、l…

LeetCode【7--整數反轉】 LeetCode【8--字符串轉整數】

整數反轉 題目描述 給出一個 32 位的有符號整數,你需要將這個整數中每位上的數字進行反轉。 解題思路 x%10 取一位,x/10下一位,注意越界, 代碼實現 class Solution { public:int reverse(int x) {int sum 0;while(x){if(s…

word2003如何設置護眼模式_ERP系統上線,如何設置采購收貨的模式,提升企業的采購效率...

如何合理的規劃采購計劃上次去拜訪一個朋友,他們說公司既然出現沒有下達采購訂單,供應商也有送貨過來的事情,對于公司來說,這個是非常嚴重的問題。若用了ERP系統之后,如何避免類似的事情發生,今天我們來分享…

LeetCode【9-- 回文數】LeetCode【10 --正則表達式的匹配】

回文數 題目描述 判斷一個整數是否是回文數。回文數是指正序(從左向右)和倒序(從右向左)讀都是一樣的整數。 解題思路 判斷該數的逆序數是不是和原數相同 代碼實現 class Solution { public:bool isPalindrome(int x) {if(…

sun鍵盤沒有stop鍵_請教Sun鍵盤

請教Sun鍵盤(2011-12-24 06:01:11)標簽:計算機雜談請教Sun鍵盤Sun鍵盤上,Help和F1之間的空白鍵是干啥的?Space旁邊的兩個菱形標志的呢?Compose呢?謝謝!請教Sun鍵盤Space旁邊的兩個菱形標志是一個類似Ctrl、Alt的修飾鍵,叫Meta。可以用Meta;鍵名來定義…

LeetCode【11--盛水最多的容器】LeetCode【12 -- 整數轉羅馬數字】

盛水最多的容器 題目描述 給定 n 個非負整數 a1,a2,…,an,每個數代表坐標中的一個點 (i, ai) 。在坐標內畫 n 條垂直線,垂直線 i 的兩個端點分別為 (i, ai) 和 (i, 0)。找出其中的兩條線,使得它們與 x 軸共…

LeetCode【13--羅馬數字轉整數】LeetCode【14--最長的公共前綴】

羅馬數字轉整數 題目描述 羅馬數字包含以下七種字符: I, V, X, L,C,D 和 M。 例如, 羅馬數字 2 寫做 II ,即為兩個并列的 1。12 寫做 XII ,即為 X II 。 27 寫做 XXVII, 即為 XX…

linux 編譯3g驅動_linux下使用3G撥號上網 以及3g驅動設置

中興WCDMA模塊 Linux撥號流程Version 1.0目錄1. 測試準備……………………………………………………..…32. 撥號腳本………………………………………………………133. 撥號過程………………………………………………………161. 測試準備本文檔測試模塊:MF210(中興W…

文件壓縮(基于LZ77的壓縮)

LZ77壓縮原理 初始LZ77 LZ77是基于字節的通用壓縮算法,它的原理就是將源文件中的重復字節(即在前文中出現的重復字節)使用(offset,length,nextchar)的三元組進行替換 這里的 長度–offset,距離—length,先行緩沖匹配…