• <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>
            隨筆-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) 閱讀(2381) 評論(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)
            @河的第三條岸
            你要精通各自的優化選項  回復  更多評論
              
            久久不见久久见免费视频7| 国产亚洲精品久久久久秋霞| 97久久精品无码一区二区天美| 久久精品无码专区免费东京热| 青青草原综合久久| 人人妻久久人人澡人人爽人人精品 | 国产国产成人久久精品| 久久久久国产亚洲AV麻豆| 伊人久久无码中文字幕| 99久久精品国产一区二区| 欧美精品乱码99久久蜜桃| 精品一区二区久久| 国产精品久久久久久久app | 国产福利电影一区二区三区久久久久成人精品综合 | 久久亚洲国产精品成人AV秋霞| 99久久久精品免费观看国产 | 久久综合给合久久狠狠狠97色69| 品成人欧美大片久久国产欧美| 亚洲精品无码久久久久| 久久久久亚洲?V成人无码| 国产精品久久国产精麻豆99网站| 久久久久久久综合狠狠综合| 97超级碰碰碰碰久久久久| 色婷婷综合久久久中文字幕| 亚洲精品国产综合久久一线| 国产成人精品久久综合| 99久久99这里只有免费的精品| 亚洲精品乱码久久久久久久久久久久 | 一本久道久久综合狠狠躁AV| 丁香久久婷婷国产午夜视频| 精品熟女少妇a∨免费久久| 亚洲国产天堂久久久久久| 久久精品成人| 国产高清美女一级a毛片久久w| 狠狠干狠狠久久| 欧美亚洲另类久久综合| 久久国产精品久久精品国产| 99久久成人国产精品免费| 97久久精品人妻人人搡人人玩| 999久久久无码国产精品| 精品综合久久久久久97超人|