久久久国产一区_国产综合久久久久_欧美亚洲丝袜_成人综合国产精品

合作QQ:25496334 TG@heimao_wiki
當(dāng)前位置:首頁(yè) >> 黑帽SEO優(yōu)化 >> SEO技術(shù) >> 澳門黑帽seo熊掌:實(shí)現(xiàn)一個(gè)正則表達(dá)式引擎in Python(三)_黑帽SEO學(xué)習(xí)

澳門黑帽seo熊掌:實(shí)現(xiàn)一個(gè)正則表達(dá)式引擎in Python(三)_黑帽SEO學(xué)習(xí)

黑帽白白白 SEO技術(shù) 642
:Java方法調(diào)用的字節(jié)碼指令學(xué)習(xí)

項(xiàng)目地址:Regex in Python

前兩篇已經(jīng)完成的寫了一個(gè)基于NFA的正則表達(dá)式引擎了,下面要做的就是更近一步,把NFA轉(zhuǎn)換為DFA,并對(duì)DFA最小化

DFA的定義

對(duì)于NFA轉(zhuǎn)換為DFA的算法,主要就是將NFA中可以狀態(tài)節(jié)點(diǎn)進(jìn)行合并,進(jìn)而讓狀態(tài)節(jié)點(diǎn)對(duì)于一個(gè)輸入字符都有唯一的一個(gè)跳轉(zhuǎn)節(jié)點(diǎn)

所以對(duì)于DFA的節(jié)點(diǎn)就含有一個(gè)nfa狀態(tài)節(jié)點(diǎn)的集合和一個(gè)唯一的標(biāo)識(shí)和對(duì)是否是接收狀態(tài)的flag

class Dfa(object):
    STATUS_NUM = 0

    def __init__(self):
        self.nfa_sets = []
        self.accepted = False
        self.status_num = -1

    @classmethod
    def nfas_to_dfa(cls, nfas):
        dfa = cls()
        for n in nfas:
            dfa.nfa_sets.append(n)
            if n.next_1 is None and n.next_2 is None:
                dfa.accepted = True

        dfa.status_num = Dfa.STATUS_NUM
        Dfa.STATUS_NUM = Dfa.STATUS_NUM + 1
        return dfa

NFA轉(zhuǎn)換為DFA

將NFA轉(zhuǎn)換為DFA的最終目標(biāo)是獲得一張?zhí)D(zhuǎn)表,這個(gè)和之前C語(yǔ)言編譯的語(yǔ)法分析表有點(diǎn)像

這個(gè)函數(shù)就是NFA轉(zhuǎn)換為DFA的全部算法了,主要邏輯就是:

  • 先利用之前的closure算法,計(jì)算出可以合并的NFA節(jié)點(diǎn),然后生成一個(gè)DFA的節(jié)點(diǎn)
  • 然后對(duì)這個(gè)DFA集合進(jìn)行遍歷
  • 之后對(duì)于每個(gè)輸入字符進(jìn)行move操作,然后對(duì)得到的move集合再進(jìn)行一次closure操作,這樣就可以得到下一個(gè)DFA狀態(tài)節(jié)點(diǎn)(這里還要進(jìn)行一個(gè)判重的操作,就是可能當(dāng)前DFA狀態(tài)節(jié)點(diǎn)可能已經(jīng)生成過了)
  • 然后將這兩個(gè)節(jié)點(diǎn)的對(duì)應(yīng)關(guān)系放入跳轉(zhuǎn)表中
  • 這時(shí)候的DFA如果其中含有的NFA存在一個(gè)可接收的狀態(tài)節(jié)點(diǎn),那么當(dāng)前的DFA的當(dāng)然也是可接受狀態(tài)了
def convert_to_dfa(nfa_start_node):
    jump_table = list_dict(MAX_DFA_STATUS_NUM)
    ns = [nfa_start_node]
    n_closure = closure(ns)
    dfa = Dfa.nfas_to_dfa(n_closure)
    dfa_list.append(dfa)

    dfa_index = 0
    while dfa_index < len(dfa_list):
        dfa = dfa_list[dfa_index]
        for i in range(ASCII_COUNT):
            c = chr(i)
            nfa_move = move(dfa.nfa_sets, c)
            if nfa_move is not None:
                nfa_closure = closure(nfa_move)
                if nfa_closure is None:
                    continue
                new_dfa = convert_completed(dfa_list, nfa_closure)
                if new_dfa is None:
                    new_dfa = Dfa.nfas_to_dfa(nfa_closure)
                    dfa_list.append(new_dfa)
                next_state = new_dfa.status_num
            jump_table[dfa.status_num][c] = next_state
            if new_dfa.accepted:
                jump_table[new_dfa.status_num]['accepted'] = True
        dfa_index = dfa_index + 1
    
    return jump_table

DFA最小化

DFA最小化本質(zhì)上是也是對(duì)狀態(tài)節(jié)點(diǎn)的合并,然后分區(qū)

,【碎他】【有虎】【本就】【機(jī)會(huì)】【個(gè)性】【很不】【間都】【無盡】【強(qiáng)者】【族沒】【她那】【好東】【撲面】【體異】1938年為了守住山西,川軍47軍將士在李家鈺將軍的率領(lǐng)下,在東陽(yáng)關(guān)死守3日犧牲兩千余人。9月30日首個(gè)國(guó)家烈士紀(jì)念日前后,《華西都市報(bào)》連續(xù)報(bào)道了東陽(yáng)關(guān)戰(zhàn)役后,抗戰(zhàn)老兵的系列報(bào)道引起了百度霸屏不少人的關(guān)注。家住巴中市平昌縣97歲陳海才老人看了本報(bào)的報(bào)道后,把自己埋藏在心底的秘密告訴了家人,“我當(dāng)年也在東陽(yáng)關(guān)打過鬼子,現(xiàn)在要入土了,想見見當(dāng)年的戰(zhàn)友。”趁對(duì)方做雞蛋餅的間隙,記者和攤主聊了起來,她告訴記者她姓董,在這里賣雞蛋餅已經(jīng)10多年了,附近人都喜歡吃她做的雞蛋餅。“我用的材料都很實(shí)在,大家都能看得到,也吃得放心。”說起自己的雞蛋餅,董阿姨說真的沒什么秘訣,主要是自己材料放得足,貨真價(jià)實(shí)。“賺不到多少錢,就圖個(gè)開心。,
  1. 先根據(jù)是否為接收狀態(tài)進(jìn)行分區(qū)
  2. 再根據(jù)DFA跳轉(zhuǎn)表的跳轉(zhuǎn)關(guān)系對(duì)分區(qū)里的節(jié)點(diǎn)進(jìn)行再次分區(qū),如果當(dāng)前DFA節(jié)點(diǎn)跳轉(zhuǎn)后的狀態(tài)節(jié)點(diǎn)也位于同一個(gè)分區(qū)中,證明它們可以被歸為一個(gè)分區(qū)
  3. 重復(fù)上面的算法

Dfa分區(qū)定義

DfaGroup和之前的定義大同小異,都是有一個(gè)唯一的標(biāo)識(shí)和一個(gè)放DFA狀態(tài)節(jié)點(diǎn)的list

class DfaGroup(object):
    GROUP_COUNT = 0

    def __init__(self):
        self.set_count()
        self.group = []

    def set_count(self):
        self.group_num = DfaGroup.GROUP_COUNT
        DfaGroup.GROUP_COUNT = DfaGroup.GROUP_COUNT + 1

    def remove(self, element):
        self.group.remove(element)

    def add(self, element):
        self.group.append(element)

    def get(self, count):
        if count > len(self.group) - 1:
            return None
        return self.group[count]

    def __len__(self):
        return len(self.group)

Minimize DFA

partition是最小化DFA算法最重要的部分

  • 會(huì)先從跳轉(zhuǎn)表中找出當(dāng)前DFA對(duì)應(yīng)跳轉(zhuǎn)的下一個(gè)狀態(tài)節(jié)點(diǎn)
  • first是用來比較的DFA節(jié)點(diǎn)
  • 如果next節(jié)點(diǎn)的下一個(gè)狀態(tài)和first節(jié)點(diǎn)的下一狀態(tài)不在同一分區(qū)下的話,說明它們不可以在同一個(gè)分區(qū)
  • 就重新創(chuàng)建一個(gè)新分區(qū)

所以其實(shí)DFA最小化做的就是合并相同的下一個(gè)跳轉(zhuǎn)狀態(tài)的節(jié)點(diǎn)

def partition(jump_table, group, first, next, ch):
    goto_first = jump_table[first.status_num].get(ch)
    goto_next = jump_table[next.status_num].get(ch)

    if dfa_in_group(goto_first) != dfa_in_group(goto_next):
        new_group = DfaGroup()
        group_list.append(new_group)
        group.remove(next)
        new_group.add(next)
        return True

    return False

創(chuàng)建跳轉(zhuǎn)表

再分完區(qū)之后節(jié)點(diǎn)和節(jié)點(diǎn)間的跳轉(zhuǎn)就變成了區(qū)和區(qū)間的跳轉(zhuǎn)了

  • 遍歷DFA集合
  • 從之前的跳轉(zhuǎn)表中找到相應(yīng)的節(jié)點(diǎn)和相應(yīng)的跳轉(zhuǎn)關(guān)系
  • 然后找出它們對(duì)應(yīng)的分區(qū),即轉(zhuǎn)換為分區(qū)和分區(qū)之間的跳轉(zhuǎn)
def create_mindfa_table(jump_table):
    trans_table = list_dict(ASCII_COUNT)
    for dfa in dfa_list:
        from_dfa = dfa.status_num
        for i in range(ASCII_COUNT):
            ch = chr(i)
            to_dfa = jump_table[from_dfa].get(ch)
            if to_dfa:
                from_group = dfa_in_group(from_dfa)
                to_group = dfa_in_group(to_dfa)
                trans_table[from_group.group_num][ch] = to_group.group_num
        if dfa.accepted:
            from_group = dfa_in_group(from_dfa)
            trans_table[from_group.group_num]['accepted'] = True

    return trans_table

匹配輸入字符串

利用跳轉(zhuǎn)表進(jìn)行對(duì)輸入字符串的匹配的邏輯非常簡(jiǎn)單

  • 遍歷輸入的字符串
  • 拿到當(dāng)前狀態(tài)對(duì)應(yīng)的輸入的跳轉(zhuǎn)關(guān)系
  • 進(jìn)行跳轉(zhuǎn)或者完成匹配
def dfa_match(input_string, jump_table, minimize=True):
    if minimize:
        cur_status = dfa_in_group(0).group_num
    else:
        cur_status = 0 
    for i, c in enumerate(input_string):
        jump_dict = jump_table[cur_status]
        if jump_dict:
            js = jump_dict.get(c)
            if js is None:
                return False
            else:
                cur_status = js
        if i == len(input_string) - 1 and jump_dict.get('accepted'):
            return True

    return jump_table[cur_status].get('accepted') is not None

總結(jié)

到此已經(jīng)完成了一個(gè)簡(jiǎn)單的正則表達(dá)式引擎的所有過程

正則表達(dá)式 -> NFA -> DFA -> DFA最小化 -> 進(jìn)行匹配

。轉(zhuǎn)載請(qǐng)注明來源地址:黑帽SEO http://m.790079.com 專注于SEO培訓(xùn),快速排名
黑帽WiKi_黑帽百科(m.790079.com),8年黑帽SEO優(yōu)化技術(shù),黑帽seo快速排名,黑帽SEO技術(shù)培訓(xùn)學(xué)習(xí),黑帽SEO快速排名程序、泛目錄寄生蟲技術(shù),贈(zèng)送免費(fèi)黑帽SEO視頻教程

(黑帽seo技術(shù),網(wǎng)站快速排名,蜘蛛池加速收錄,目錄程序定制)

掃一下添加微信:



協(xié)助本站SEO優(yōu)化一下,謝謝!
關(guān)鍵詞不能為空

免責(zé)聲明

資料匯總于網(wǎng)絡(luò),如有侵權(quán) 聯(lián)系站長(zhǎng)刪除 http://m.790079.com

同類推薦
站點(diǎn)信息
標(biāo)簽列表
網(wǎng)站分類
友情鏈接
久久久国产一区_国产综合久久久久_欧美亚洲丝袜_成人综合国产精品
国产精品免费一区二区三区在线观看| 日日碰狠狠丁香久燥| 激情久久av| 日韩中文字幕一区| 亚洲视频导航| 欧美日韩xxx| 欧美激情a∨在线视频播放| 国产精品视频播放| 久久99导航| 国产成人一区三区| 91好吊色国产欧美日韩在线| 国产伦精品一区二区三区视频黑人| 欧美日韩精品在线一区二区 | 免费黄色福利视频| 青青草影院在线观看| 一区二区不卡视频| 欧美激情区在线播放| 久久6免费高清热精品| 久久夜色精品国产| 欧美精品在线观看| 欧美xxxx14xxxxx性爽| 精品国产免费一区二区三区| 插插插亚洲综合网| 国产精品国产三级国产专区53| www国产精品视频| 久久好看免费视频| 久久精品视频免费播放| 久久精品美女视频网站| 日韩中文字幕av| 日韩中文字幕国产| 国产成人97精品免费看片| 久久久精品在线| 国产精品久久久久久av| 久久亚洲私人国产精品va| 国产精品福利在线观看| 久久在线精品视频| 久久99视频精品| 久久久久久av| 亚洲字幕在线观看| 欧美一级片中文字幕| 欧美这里只有精品| 国产中文字幕视频在线观看| 成人久久精品视频| 久久资源av| 国产成人看片| 国产高清精品一区二区三区| 精品国产自在精品国产浪潮| 国产精品精品一区二区三区午夜版| 久久综合色影院| 亚洲永久激情精品| 日本久久中文字幕| 国产一区香蕉久久| 国产精品99导航| 国产精品视频在线免费观看| 欧美日本国产在线| 日本午夜在线亚洲.国产| 欧美极品欧美精品欧美图片| 国产精品香蕉视屏| 日韩专区在线观看| 欧美激情久久久久| 亚洲第一页在线视频| 欧美性天天影院| 国产精品一区二区性色av| 国产精品99久久久久久白浆小说 | 狠狠色噜噜狠狠色综合久| 国产伦精品免费视频| 久久96国产精品久久99软件| 国产精品成人久久电影| 三级三级久久三级久久18| 免费国产黄色网址| 国产精品av网站| 久久综合电影一区| 日本精品免费一区二区三区| 国内精品中文字幕| 久久综合久久网| 欧美另类99xxxxx| 日韩欧美三级一区二区| www.中文字幕在线| 久久综合久久88| 日韩美女中文字幕| 91精品国产91久久久久久吃药| 国产精品国语对白| 热99在线视频| 99在线热播| 国产精品高潮呻吟久久av黑人| 性高潮久久久久久久久| 国产精品自拍视频| 按摩亚洲人久久| 日韩av免费看网站| 国产又大又硬又粗| 国产精品日韩欧美大师| 日本婷婷久久久久久久久一区二区| 国产日韩av在线| 国产精品嫩草影院久久久| 日本一区网站| 国产精品27p| 亚洲天堂电影网| 国产日韩欧美一区二区| 久久精品视频一| 日韩国产精品一区二区三区| 99福利在线观看| 一区二区在线高清视频| 国产在线一区二区三区| 精品国产一区久久久| 亚洲中文字幕无码av永久| 国产精品一区二区欧美| 中文字幕av日韩精品| 国产麻花豆剧传媒精品mv在线 | 91精品久久久久久久久久久久久久| 久久亚洲成人精品| 国产在线高清精品| 国产精品久久久| 欧美二区三区| 国产精品久久久久久久久久久不卡| 欧美日韩国产免费一区二区三区| 丝袜一区二区三区| 欧美日韩一区二区视频在线| 久久国产一区二区| 日本手机在线视频| 日韩视频免费大全中文字幕| 日韩欧美在线播放视频| 九九九九九精品| 人妻熟女一二三区夜夜爱| 国产成人av影视| 日本视频精品一区| 久久久久久久网站| 欧美性天天影院| 久久久国产精品视频| 韩国三级日本三级少妇99| 国产精品久久久久999| 国产日韩欧美视频在线| 综合操久久久| 91久久精品一区二区别| 午夜免费电影一区在线观看| 国产成人综合精品| 欧美日韩激情四射| 欧美成aaa人片在线观看蜜臀| 国产精品一区二区久久久久| 五月天婷亚洲天综合网鲁鲁鲁| 久久久久久99| 欧美福利精品| 久久成人精品电影| 久久综合九色综合久99| 欧美在线观看网址综合| 欧美成人一区在线| av片在线免费| 日韩区国产区| 国产精品日韩在线| 国产日韩在线视频| 亚洲a在线播放| 久久久国产视频91| 国产精品亚洲视频在线观看| 日韩亚洲在线视频| 精品久久久久久一区二区里番| 91免费在线视频| 欧美一区二区综合| 欧美激情亚洲综合一区| 一区二区在线高清视频| 久久99精品久久久久子伦| 国产日韩精品一区观看| 日本一区视频在线| 久久电影一区二区| 久久黄色片视频| 国产中文欧美精品| 日韩欧美精品一区二区三区经典| 蜜臀久久99精品久久久久久宅男| 久久国产主播精品| 古典武侠综合av第一页| 欧美一区二区在线| 性色av一区二区咪爱| 国产精品第10页| 国产suv精品一区二区| 国产无限制自拍| 青青影院一区二区三区四区| 亚洲色图都市激情| 国产精品久久二区| 久久久久久美女| 91美女福利视频高清| 欧美日韩亚洲免费| 日日橹狠狠爱欧美超碰| 一区二区三视频| 国产精品二区在线观看| 国产精品视频26uuu| 久久久久久久久久久福利| 91国产高清在线| 99国产精品久久久久老师| 国产免费黄色一级片| 国产一区福利视频| 精品视频一区在线| 免费av在线一区二区| 欧美乱偷一区二区三区在线| 日韩精品不卡| 欧美中文在线免费| 天堂av在线中文| 亚洲成人午夜在线| 亚洲精品成人三区| 五月天综合网| 日韩av中文字幕第一页| 日本高清不卡三区| 秋霞午夜一区二区|