10.正則表達式匹配

class Solution:
    def isMatch(self, s: str, p: str) -> bool:
        # 判空(結(jié)束)
        if not s and not p:
            return True
        elif s and not p:
            return False
        # s 第一列表示 s 的 ^
        dp = [[False] * (len(s) + 1) for i in range(len(p))]
        # 處理第一列
        if len(p) > 1:
            dp[1][0] = p[1] == '*'
        for y in range(2, len(p)):
            if not dp[y - 1][0] and not dp[y - 2][0]:
                break
            dp[y][0] = p[y] == '*'
        # 處理第一行剩下的部分
        if s:
            dp[0][1] = p[0] == s[0] or p[0] == '.'
        for y in range(1, len(p)):
            for x in range(1, len(s) + 1):
                # 先橫再豎
                if p[y] == '*':
                    # 上方為 T 或上上為 T 必為 T酒繁,上為 T 表示這里 * 代表 1奕翔,上為 F 上上為 T 表示這里 * 為 0
                    if dp[y - 1][x] or dp[y - 2][x]:
                        dp[y][x] = True
                    # 其余情況首先左為 T季研,然后看看上一個 p 是不是能匹配當(dāng)前的 s挟憔,左為 T 說明這里的 * 為 > 2磕仅,要檢測能否繼續(xù)匹配
                    elif dp[y][x - 1] and (p[y - 1] == '.' or p[y - 1] == s[x - 1]):
                        dp[y][x] = True
                elif p[y] == '.':
                    # 如果左上是 T 那么這里必為 T,s 和 p 都向后移動匹配下一個字符浊洞,反過來需要前面的能匹配上
                    if dp[y - 1][x - 1]:
                        dp[y][x] = True
                else:
                    # 普通字符的時候如果左上方已經(jīng)為 F 則必為 F把曼,同 .,s 和 p 都向后移動匹配下一個字符摄乒,反過來需要前面的能匹配上
                    if dp[y - 1][x - 1] and p[y] == s[x - 1]:
                        dp[y][x] = True
        return dp[-1][-1]
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末悠反,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子馍佑,更是在濱河造成了極大的恐慌斋否,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,589評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拭荤,死亡現(xiàn)場離奇詭異茵臭,居然都是意外死亡,警方通過查閱死者的電腦和手機舅世,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評論 3 396
  • 文/潘曉璐 我一進店門旦委,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人雏亚,你說我怎么就攤上這事缨硝。” “怎么了罢低?”我有些...
    開封第一講書人閱讀 165,933評論 0 356
  • 文/不壞的土叔 我叫張陵查辩,是天一觀的道長。 經(jīng)常有香客問我,道長宜岛,這世上最難降的妖魔是什么长踊? 我笑而不...
    開封第一講書人閱讀 58,976評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮萍倡,結(jié)果婚禮上身弊,老公的妹妹穿的比我還像新娘。我一直安慰自己遣铝,他們只是感情好佑刷,可當(dāng)我...
    茶點故事閱讀 67,999評論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著酿炸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪涨冀。 梳的紋絲不亂的頭發(fā)上填硕,一...
    開封第一講書人閱讀 51,775評論 1 307
  • 那天,我揣著相機與錄音鹿鳖,去河邊找鬼扁眯。 笑死,一個胖子當(dāng)著我的面吹牛翅帜,可吹牛的內(nèi)容都是我干的姻檀。 我是一名探鬼主播,決...
    沈念sama閱讀 40,474評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼涝滴,長吁一口氣:“原來是場噩夢啊……” “哼绣版!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起歼疮,我...
    開封第一講書人閱讀 39,359評論 0 276
  • 序言:老撾萬榮一對情侶失蹤杂抽,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后韩脏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體缩麸,經(jīng)...
    沈念sama閱讀 45,854評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,007評論 3 338
  • 正文 我和宋清朗相戀三年赡矢,在試婚紗的時候發(fā)現(xiàn)自己被綠了杭朱。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,146評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡吹散,死狀恐怖弧械,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情送浊,我是刑警寧澤梦谜,帶...
    沈念sama閱讀 35,826評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響唁桩,放射性物質(zhì)發(fā)生泄漏闭树。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,484評論 3 331
  • 文/蒙蒙 一荒澡、第九天 我趴在偏房一處隱蔽的房頂上張望报辱。 院中可真熱鬧,春花似錦单山、人聲如沸碍现。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,029評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽昼接。三九已至,卻和暖如春悴晰,著一層夾襖步出監(jiān)牢的瞬間慢睡,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,153評論 1 272
  • 我被黑心中介騙來泰國打工铡溪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留漂辐,地道東北人。 一個月前我還...
    沈念sama閱讀 48,420評論 3 373
  • 正文 我出身青樓棕硫,卻偏偏與公主長得像髓涯,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子哈扮,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,107評論 2 356