Last updated
Last updated
這一題是正規表達式的題目,主要有兩個符號要考慮:「.」和「*」,點號和星號,點號比較好處理,因為只要是點好,就代表可以跳過該字元,最難處理的是星號。因為星號可以代表的是該字元可以出現零到無限次。其中又以.*
代表的是可以符合任何字元無限次。
下面是如果只以 .
當作匹配的字串時所做的考量。
接下來要考慮的是如果有 *
的情況。
因為星號會出現在下一個位置,所以我們要看的是 p[j+1]
的情況。並且要小心的處理邊界。
接下來要考慮的情況分成
當 s[i] == p[j] or p[j] == '.'
:
p[j+1] != '*'
兩個指針往前走。
p[j+1] == '*'
可以匹配零到多個字元,例如匹配零個字元:s = "aa", p = "a*aa"
匹配多個字元:s = "aaa", p = "a*"
。
當 s[i] != p[j]
:
p[j+1] != '*'
不匹配,回傳 False
p[j+1] == '*'
只能匹配零個字元,例如:s = "cc", p = "ca*c"
。
分析到這裡,最困難的就是 1-2 到底要怎麼選擇,到底要不要匹配字元,於是我們可以改寫
可是到了這一步還沒有結束,因為我們要知道 Base case 的終止條件。
第一個終止條件很簡單,那就是 j
指針指向 p
的終點的時候,i
剛好也在 s
的終點。
可是當 i
在 s 的終點的時候不能只是簡單的判斷 j
是不是也在終點,例如:p
在 j
位置之後是一連串的 a*b*c*d*a*c*...
這樣的字串。這些判斷是都可以是作為空字串的判斷。
要做出這樣的判斷有二個條件,第一個條件是這串字串一定要是偶數長度,如果是奇數長度就不用考慮一定是回傳 False 。
當是偶數後,才進行第二個判斷,這串出現星號的字串一定是一個字母或甚至一的點號加上星號。
這裡有兩個方法,由於所以可以乾脆去用星號分開所有的字元,如果說有字元的長度超過 1 ,那就代表還有一個字元需要匹配,回傳 False ,如果說所以的字元都檢查完了,都有星號那就可以回傳 True
又或是另一種檢查法,每次跳兩格,一路檢查到看是不是星號。
兩種方法都可以,可以看自己想要怎麼選擇。