青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-19  評論-21  文章-0  trackbacks-0
一. 簡介

    該正則表達式暫時能識別 *,|,(,)等特殊符號,如(a|b)*abc。不過擴展到其他符號(如?)也相對比較容易,修改NFA中的構建規則即可。

二. 引擎的構建

    該正則表達式引擎的構建以《Compilers Principles,Techniques & Tools》3.7節為依據,暫時只能識別*,|,(,)這幾個特殊的字符,其工作過程為:構建NFA -> 根據NFA構建DFA -> 用DFA匹配。

1. 構建NFA
該NFA的構建以2條基本規則和3條組合規則為基礎,采用歸納的思想構建而成。
1)2條基本的規則是:
a. 以一個空值ε構建一個NFA

b. 以一個字符a構建一個NFA

2) 3條組合規則是:
a. r = s | t (其中s和t都是NFA)

b. r = s t(其中s和t都是NFA)

c. r = s *(其中s為NFA)

3) 如果需要識別如”?”等特殊符號,則可再加一些組合規則。

在具體的程序中,可以以下面的BNF為結構來實現。(具體見源程序regexp.cpp)

-> r '|' s | r
-> s t | s
-> a '*' | a
-> token | '(' r ')' | ε   

2. 構建DFA
主要是求ε閉包的過程,從一個集合的ε閉包轉移到一個集合的ε閉包。
以a*c為例,其NFA圖如下所示(用dot畫的)

為例:
起始結點3的ε閉包集為 A = {3,1,4}
A遇上字母a的轉移為MOV(A,a) = { 2 },其ε閉包集為B = { 2,1,4 }
A遇上字母c的轉移為MOV(A,c) = { 6 },其ε閉包集為B = { 6 }
同理可求出其他轉移集合,最后得到的DFA如下所示:

3. 匹配
每匹配成功一個字符則DFA移動到下個相應的結點。

三. 改進

1. 如龍書中所說,有時候模擬NFA而不是直接構建DFA可能達到更好的效果。
2. 每次匹配不成功都需要回溯,這個地方也可以借鑒KMP算法(不過KMP對此好像有點不適用)
3. 其他改進方法可以看看《柔性字符串匹配》和龍書《Compilers Principles,Techniques & Tools》3.7節。

四. 代碼下載

svn checkout http://regexp.googlecode.com/svn/trunk/ regexp-read-only

regexp.rar
posted on 2010-06-17 20:50 hex108 閱讀(730) 評論(2)  編輯 收藏 引用 所屬分類: Program

評論:
# re: 構建正則表達式引擎 2010-06-18 18:23 | 木頭奎
發現一處代碼問題:
NFA *construct_nfa_and(NFA *s,NFA *t)函數體里面,
delete( t->get_head() ); //釋放t的頭結點
這句話
應該放到s->set_tail( t->get_tail() );的后面去

VC6下測試發現的。  回復  更多評論
  
# re: 構建正則表達式引擎 2010-06-18 21:01 | hex108
@木頭奎
謝謝! 剛改正了呵  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久青草久久| 国产午夜精品美女毛片视频| 亚洲高清在线观看| 亚洲一级在线| 亚洲图片在线观看| 亚洲精品视频在线播放| 黄色日韩网站视频| 一区二区三区在线视频观看| 国产精品少妇自拍| 国产一区再线| 最新成人在线| 一区二区欧美激情| 午夜电影亚洲| 久久九九99视频| 欧美成人网在线| 一本色道综合亚洲| 亚洲男人的天堂在线观看| 先锋影音久久| 免费欧美在线| 国产日韩欧美| 亚洲一区二区3| 国产精品99久久久久久久女警| 欧美视频在线观看免费| 欧美一区二区三区在线观看| 久久精品二区三区| 亚洲一区免费视频| 欧美黄色一区| 一本大道久久精品懂色aⅴ| 亚洲欧美日韩系列| 亚洲午夜极品| 狠狠爱成人网| 亚洲激情成人| 久久综合九九| 91久久精品日日躁夜夜躁欧美| 欧美风情在线观看| 久久婷婷久久| 日韩一区二区免费高清| 久久成人免费网| 亚洲国产精品一区在线观看不卡 | 久久九九久精品国产免费直播 | 午夜免费日韩视频| 在线电影国产精品| 亚洲欧美日本另类| 亚洲小说欧美另类婷婷| 久久久999成人| 久久国产成人| 国产精品在线看| 国产日韩欧美一区| 国产一区二区三区直播精品电影| 欧美成人午夜激情| 欧美精品一区二| 极品少妇一区二区| 一区二区三区日韩| 亚洲国产婷婷香蕉久久久久久| 中文国产成人精品| 久久亚洲一区二区三区四区| 欧美在线播放高清精品| 亚洲三级色网| 久久综合给合久久狠狠色| 国产日韩av一区二区| 亚洲影院色无极综合| 国产精品青草久久久久福利99| 亚洲精品社区| 久久综合久久美利坚合众国| 欧美一区二区三区免费大片| 国产欧美激情| 久久久噜噜噜久久狠狠50岁| 欧美伊久线香蕉线新在线| 国产精品一级二级三级| 欧美呦呦网站| 久久久精品999| 亚洲欧洲美洲综合色网| 亚洲激情影院| 欧美日韩一区免费| 亚洲自拍偷拍网址| 亚洲一级黄色片| 国产主播精品| 亚洲观看高清完整版在线观看| 欧美乱妇高清无乱码| 宅男噜噜噜66一区二区| 亚洲校园激情| 激情文学一区| 亚洲精品视频二区| 国产欧美精品在线播放| 玖玖国产精品视频| 欧美精品免费在线| 欧美一区观看| 老司机久久99久久精品播放免费| 亚洲美女视频在线观看| 欧美日韩国产精品一区二区亚洲| 久久精品国产成人| 亚洲一级在线观看| 亚洲在线成人精品| 国产精品jizz在线观看美国| 亚洲欧美日韩天堂| 久久久亚洲国产天美传媒修理工| 亚洲国产一区二区三区高清| 亚洲精品美女在线观看播放| 欧美午夜精品久久久| 久久国产日韩欧美| 欧美成年网站| 欧美在线3区| 免费在线播放第一区高清av| 亚洲一区尤物| 久久夜色精品国产欧美乱极品| 一区二区不卡在线视频 午夜欧美不卡'| 亚洲精品一区二区三区四区高清| 国产伦精品一区二区三区免费迷| 欧美激情第三页| 国产精品久久久爽爽爽麻豆色哟哟| 久久久国产精品一区| 欧美精品大片| 久久一区国产| 国产毛片久久| 日韩一区二区精品视频| 1024亚洲| 久久aⅴ国产紧身牛仔裤| 一区二区三区久久| 麻豆freexxxx性91精品| 久久成人18免费观看| 欧美日韩一区二区在线观看| 欧美激情一区二区三区蜜桃视频| 国产午夜精品美女视频明星a级| 国产精品综合网站| 久久gogo国模啪啪人体图| 欧美激情中文不卡| 欧美91视频| 黄色成人av| 午夜在线成人av| 香蕉国产精品偷在线观看不卡 | 亚洲欧美中文字幕| 亚洲精品久久嫩草网站秘色| 很黄很黄激情成人| 久久国产视频网| 久久精品国产精品| 国产伦精品一区二区三区四区免费 | 欧美日韩另类视频| 91久久精品国产91性色| 亚洲欧洲综合另类| 免费欧美日韩国产三级电影| 欧美成人在线免费视频| 狠狠色伊人亚洲综合网站色 | 欧美日本韩国| 亚洲人成在线观看网站高清| 亚洲理论在线| 欧美日韩一区在线视频| 夜色激情一区二区| 亚洲男女自偷自拍图片另类| 国产精品视频你懂的| 亚洲欧美在线另类| 久久婷婷国产综合精品青草| 尤物网精品视频| 欧美成人亚洲| 亚洲桃花岛网站| 久久久久久久综合日本| 在线成人激情视频| 欧美激情黄色片| 中文有码久久| 久久一区二区精品| 99国产欧美久久久精品| 国产精品久久久久影院亚瑟| 久久国产黑丝| 亚洲精品孕妇| 欧美一级免费视频| 雨宫琴音一区二区在线| 欧美激情中文字幕一区二区| 一区二区欧美在线| 久久久99国产精品免费| 亚洲国产精品久久久久| 欧美日韩国产综合新一区| 亚洲男人的天堂在线| 欧美国产视频一区二区| 亚洲在线观看视频网站| 黄色成人免费网站| 欧美另类视频| 久久天天躁夜夜躁狠狠躁2022| 亚洲精品在线观| 麻豆精品传媒视频| 亚洲天堂网站在线观看视频| 激情一区二区三区| 欧美日韩一区二区三区在线观看免| 亚洲愉拍自拍另类高清精品| 欧美福利电影在线观看| 亚洲女性喷水在线观看一区| 一区二区亚洲精品国产| 国产精品qvod| 国产视频一区在线| 亚洲精品一区中文| 国产日韩欧美视频| 欧美日韩免费在线| 久久亚洲一区| 欧美一区二区三区免费视| 日韩视频―中文字幕| 男男成人高潮片免费网站| 欧美一区二区三区四区在线| 最新日韩av| 欧美xart系列高清| 久久精品最新地址| 午夜老司机精品| 亚洲天堂av在线免费观看|