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

隨筆-341  評論-2670  文章-0  trackbacks-0

    這篇文章的代碼所描述的算法在這里有詳細的說明。

    Epsilon-NFA到NFA的目標主要是產生一個沒有Epsilon邊的,跟原狀態圖等價的新狀態圖。過程不復雜,首先從起始狀態開始,尋找所有Epsilons邊到達的對象的集合,然后復制這個集合的所有狀態包含的非Epsilon狀態。其實狀態做完之后,尋找所有能夠產生非Epsilon邊的狀態然后重復這個過程,最后NFA就出來了。代碼如下:

 1         Automaton::Ref EpsilonNfaToNfa(Automaton::Ref source, bool(*epsilonChecker)(Transition*))
 2         {
 3             Automaton::Ref target=new Automaton;
 4             Dictionary<State*, State*> stateMap;
 5             Dictionary<State*, State*> reverseStateMap;
 6             List<State*> epsilonStates;
 7             stateMap.Add(source->startState, target->NewState());
 8             reverseStateMap.Add(stateMap[source->startState], source->startState);
 9             target->startState=target->states[0].Obj();
10             CopyFrom(target->captureNames.Wrap(), source->captureNames.Wrap());
11 
12             for(int i=0;i<target->states.Count();i++)
13             {
14                 State* targetState=target->states[i].Obj();
15                 State* sourceState=reverseStateMap[targetState];
16                 if(sourceState->finalState)
17                 {
18                     targetState->finalState=true;
19                 }
20                 epsilonStates.Clear();
21                 epsilonStates.Add(sourceState);
22 
23                 for(int j=0;j<epsilonStates.Count();j++)
24                 {
25                     State* currentState=epsilonStates[j];
26                     for(int k=0;k<currentState->transitions.Count();k++)
27                     {
28                         Transition* transition=currentState->transitions[k];
29                         if(epsilonChecker(transition) && !epsilonStates.Contains(transition->target))
30                         {
31                             if(transition->target->finalState)
32                             {
33                                 targetState->finalState=true;
34                             }
35                             epsilonStates.Add(transition->target);
36                         }
37                     }
38                 }
39                 
40                 for(int j=0;j<epsilonStates.Count();j++)
41                 {
42                     State* epsilonState=epsilonStates[j];
43                     for(int k=0;k<epsilonState->transitions.Count();k++)
44                     {
45                         Transition* nonEpsilonTransition=epsilonState->transitions[k];
46                         if(!epsilonChecker(nonEpsilonTransition))
47                         {
48                             if(!stateMap.Keys().Contains(nonEpsilonTransition->target))
49                             {
50                                 stateMap.Add(nonEpsilonTransition->target, target->NewState());
51                                 reverseStateMap.Add(stateMap[nonEpsilonTransition->target], nonEpsilonTransition->target);
52                             }
53                             Transition* newTransition=target->NewTransition(targetState, stateMap[nonEpsilonTransition->target]);
54                             newTransition->capture=nonEpsilonTransition->capture;
55                             newTransition->index=nonEpsilonTransition->index;
56                             newTransition->range=nonEpsilonTransition->range;
57                             newTransition->type=nonEpsilonTransition->type;
58                         }
59                     }
60                 }
61             }
62             return target;
63         }

    我們來看一個例子:(/+|-)?/d+(./d+)?

   
這是一個判斷一個字符串是不是小數的正則表達式,首先是Epsilon-NFA:
 1 [START]State<0>
 2     To State<2> : <Epsilon>
 3     To State<4> : <Epsilon>
 4     To State<1> : <Epsilon>
 5 State<1>
 6     To State<6> : <Epsilon>
 7 State<2>
 8     To State<3> : <Char : 43[+- 43[+]>
 9 State<3>
10     To State<1> : <Epsilon>
11 State<4>
12     To State<5> : <Char : 45[-- 45[-]>
13 State<5>
14     To State<1> : <Epsilon>
15 State<6>
16     To State<7> : <Char : 48[0- 57[9]>
17 State<7>
18     To State<8> : <Epsilon>
19     To State<10> : <Epsilon>
20 State<8>
21     To State<9> : <Char : 48[0- 57[9]>
22 State<9>
23     To State<7> : <Epsilon>
24 State<10>
25     To State<11> : <Char : 46[.] - 46[.]>
26     To State<13> : <Epsilon>
27 State<11>
28     To State<12> : <Epsilon>
29 State<12>
30     To State<13> : <Char : 48[0- 57[9]>
31 [FINISH]State<13>
32     To State<14> : <Epsilon>
33 State<14>
34     To State<15> : <Char : 48[0- 57[9]>
35 State<15>
36     To State<13> : <Epsilon>
37 

    然后是NFA,也就是今天這個算法的結果:
 1 [START]State<0>
 2     To State<1> : <Char : 43[+- 43[+]>
 3     To State<2> : <Char : 45[-- 45[-]>
 4     To State<3> : <Char : 48[0- 57[9]>
 5 State<1>
 6     To State<3> : <Char : 48[0- 57[9]>
 7 State<2>
 8     To State<3> : <Char : 48[0- 57[9]>
 9 [FINISH]State<3>
10     To State<4> : <Char : 48[0- 57[9]>
11     To State<5> : <Char : 46[.] - 46[.]>
12     To State<6> : <Char : 48[0- 57[9]>
13 [FINISH]State<4>
14     To State<4> : <Char : 48[0- 57[9]>
15     To State<5> : <Char : 46[.] - 46[.]>
16     To State<6> : <Char : 48[0- 57[9]>
17 State<5>
18     To State<7> : <Char : 48[0- 57[9]>
19 [FINISH]State<6>
20     To State<6> : <Char : 48[0- 57[9]>
21 [FINISH]State<7>
22     To State<6> : <Char : 48[0- 57[9]>
23 

    接下來就是NFA到DFA的生成了。
posted on 2009-10-28 04:34 陳梓瀚(vczh) 閱讀(2421) 評論(7)  編輯 收藏 引用 所屬分類: VL++3.0開發紀事

評論:
# re: Vczh Library++3.0之正則表達式引擎(Epsilon-NFA到NFA) 2009-11-03 18:34 | SonicLing
博主的編碼風格變了,由Dephi轉向C#了。  回復  更多評論
  
# re: Vczh Library++3.0之正則表達式引擎(Epsilon-NFA到NFA) 2009-12-08 17:38 | 河的第三條岸
你好,請問把epsilon nfa 轉化為 nfa 的意義是什么呢? 這個算法和子集構造算法有什么區別?謝謝  回復  更多評論
  
# re: Vczh Library++3.0之正則表達式引擎(Epsilon-NFA到NFA) 2009-12-10 03:42 | 陳梓瀚(vczh)
@河的第三條岸
意義在于程序寫起來簡單,不知道什么是子集構造算法。  回復  更多評論
  
# re: Vczh Library++3.0之正則表達式引擎(Epsilon-NFA到NFA) 2009-12-10 04:49 | 河的第三條岸
@陳梓瀚(vczh)
謝謝回復。
子集構造算法(powerset construction or subset construction) 是把nfa轉為dfa的標準算法。
我的程序在把正則表達式編譯成dfa時速度太慢了(200個的話要10分鐘左右),所以想把nfa化簡一下,看到了你的文章,所以想問問你化簡nfa的方法
  回復  更多評論
  
# re: Vczh Library++3.0之正則表達式引擎(Epsilon-NFA到NFA) 2009-12-11 09:57 | 陳梓瀚(vczh)
@河的第三條岸
最普通的算法,就是記錄所有出現過的nfa狀態集合。話說沒那么夸張吧,我認為是你代碼的問題,不是你算法的問題。  回復  更多評論
  
# re: Vczh Library++3.0之正則表達式引擎(Epsilon-NFA到NFA) 2009-12-12 00:20 | 河的第三條岸
@陳梓瀚(vczh)
謝謝。
代碼應該是有一些問題,我也正在找。但是編譯器的問題也很大,vc,gcc運行時間差異也很大。  回復  更多評論
  
# re: Vczh Library++3.0之正則表達式引擎(Epsilon-NFA到NFA) 2009-12-12 22:25 | 陳梓瀚(vczh)
@河的第三條岸
你要精通各自的優化選項  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美ab在线视频| 亚洲精品影视| 亚洲视频中文字幕| 亚洲黄色毛片| 久久国产精品久久久久久电车| 一个色综合av| 欧美高清视频www夜色资源网| 久久精品国产96久久久香蕉| 欧美午夜一区二区福利视频| 亚洲精品免费在线| 亚洲国产精品久久久久婷婷884| 亚洲综合欧美日韩| 亚洲视频二区| 欧美天天综合网| 亚洲精品综合| 亚洲作爱视频| 欧美日韩免费观看一区 | 欧美一区二区三区精品电影| 欧美午夜精品久久久| 99在线精品视频| 中文国产亚洲喷潮| 欧美日韩一区二区三区视频| 亚洲精品极品| 亚洲午夜久久久久久久久电影院| 欧美成人精品激情在线观看 | 一区二区三区欧美成人| 一区二区欧美视频| 欧美日韩国产成人| 一本色道久久综合一区| 亚洲一区二区三区视频播放| 欧美日韩在线播| 亚洲一区精彩视频| 久久精品国产一区二区三| 国产亚洲欧洲一区高清在线观看| 午夜精品久久久久久久白皮肤| 欧美亚洲三区| 国语自产精品视频在线看一大j8| 欧美一区二区| 欧美h视频在线| 亚洲人成小说网站色在线| 欧美激情亚洲精品| 中文亚洲视频在线| 久久精品亚洲精品国产欧美kt∨| 国产中文一区二区三区| 久久婷婷久久| 99视频在线精品国自产拍免费观看| 亚洲欧美日韩第一区| 国产一区二区电影在线观看| 久久综合伊人77777尤物| 亚洲国产一区二区三区在线播 | 欧美日韩亚洲一区二区三区| 中国女人久久久| 久久精品夜色噜噜亚洲aⅴ| 在线日韩av片| 欧美日韩在线综合| 久久精品一区| 99成人精品| 久久人人97超碰人人澡爱香蕉| 亚洲黄色高清| 国产区欧美区日韩区| 免费一级欧美片在线播放| 一区二区三区国产精华| 老鸭窝毛片一区二区三区| 夜夜嗨av一区二区三区网站四季av| 国产伦精品一区二区三区在线观看| 久久久久青草大香线综合精品| 亚洲人线精品午夜| 久久久成人精品| 亚洲婷婷综合久久一本伊一区| 狠狠色狠狠色综合日日91app| 欧美激情中文不卡| 久久精品理论片| 一区二区高清| 亚洲黄色成人久久久| 久久久精品国产免大香伊| 一区二区久久久久久| 亚洲第一综合天堂另类专| 国产裸体写真av一区二区| 欧美日韩高清一区| 美女主播视频一区| 久久精品免视看| 午夜日韩在线观看| 一区二区三区四区五区精品| 欧美成人69av| 久久久夜夜夜| 欧美一区二区三区免费观看视频| 99re6这里只有精品| 尤物在线精品| 国产真实乱子伦精品视频| 国产精品男女猛烈高潮激情 | 亚洲午夜久久久久久久久电影网| 在线观看欧美一区| 国产一二三精品| 国产精品影片在线观看| 欧美视频中文一区二区三区在线观看 | 亚洲制服av| 一区二区欧美精品| 99国产精品99久久久久久粉嫩| 亚洲第一视频网站| 欧美成人嫩草网站| 欧美jizz19hd性欧美| 老巨人导航500精品| 久久美女性网| 老鸭窝91久久精品色噜噜导演| 久久精品人人做人人爽| 欧美一区在线看| 久久国产精品久久久久久| 欧美在线观看视频一区二区三区| 亚洲在线一区二区| 亚洲欧美日韩精品综合在线观看| 亚洲一区二区三区精品视频 | 欧美在线免费播放| 欧美一区二区三区四区夜夜大片| 亚洲欧美在线高清| 欧美一区二区三区免费在线看| 欧美影院成年免费版| 欧美中文字幕第一页| 久久亚洲精品一区| 欧美成人资源| 亚洲精品欧美极品| 亚洲一区二区3| 午夜在线电影亚洲一区| 久久精品视频免费| 男人天堂欧美日韩| 欧美午夜宅男影院| 国模吧视频一区| 亚洲国产精品久久人人爱蜜臀| 日韩视频一区二区三区在线播放免费观看| 亚洲精品中文字幕女同| 亚洲特级毛片| 久久九九精品99国产精品| 欧美激情国产日韩| 亚洲另类春色国产| 欧美亚洲色图校园春色| 麻豆久久久9性大片| 国产精品扒开腿做爽爽爽软件| 国产欧美精品在线播放| 亚洲电影在线观看| 亚洲性图久久| 蜜臀av性久久久久蜜臀aⅴ| 亚洲精品久久久久久一区二区| 亚洲永久在线| 欧美成人精品1314www| 国产精品欧美一区二区三区奶水| 国模精品娜娜一二三区| 99精品视频免费观看| 欧美在线二区| 最近看过的日韩成人| 午夜免费在线观看精品视频| 免费亚洲网站| 国产一级久久| 亚洲一区二区三区四区中文 | 亚洲大胆人体视频| 亚洲综合欧美日韩| 欧美精品在线免费播放| 国内精品久久久久影院色| 亚洲午夜激情| 欧美成人精品不卡视频在线观看| 亚洲午夜电影网| 欧美成人国产| 国内精品一区二区三区| 亚洲综合999| 亚洲国产成人av| 久久精品国产久精国产思思| 欧美视频一区二区三区四区| 亚洲国产成人tv| 久久九九精品99国产精品| 国产精品99久久久久久白浆小说| 欧美freesex交免费视频| 国语精品一区| 欧美在线视频在线播放完整版免费观看 | 亚洲一区在线播放| 欧美日韩国产成人在线观看| 亚洲国产人成综合网站| 久久久精品国产一区二区三区| 一本大道久久a久久综合婷婷| 免费永久网站黄欧美| 亚洲第一伊人| 欧美成人国产va精品日本一级| 久久国产黑丝| 国产在线视频不卡二| 欧美在线影院| 午夜久久福利| 国产伪娘ts一区| 欧美一区二区免费观在线| 中文国产成人精品久久一| 欧美全黄视频| 亚洲精品一区中文| 亚洲国产专区校园欧美| 欧美精品粉嫩高潮一区二区 | 亚洲黄色小视频| 欧美成人黑人xx视频免费观看| 久久久久久久久久久久久9999| 精品不卡一区| 嫩草国产精品入口| 久久综合色88| 亚洲精品自在久久| 99天天综合性| 国产精品丝袜xxxxxxx| 欧美综合激情网|