zoukankan      html  css  js  c++  java
  • LL(1)文法的判断

    一、文法 G(S):

    (1)S -> AB

    (2)A ->Da|ε

    (3)B -> cC

    (4)C -> aADC |ε

    (5)D -> b|ε

    验证文法 G(S)是不是 LL(1)文法。

     

    FIRST集:

    FIRST(Da)={b,a}

    FIRST(ε)={ε}

    FIRST(aADC)={a}

    FIRST(b)={b}

     

    FOLLOW集:

    FOLLOW(A)=FIRST(B)+FIRST(B)+FIRST(B)+FOLLOW(C)={c,a,b,#}

    FOLLOW(C)={#}

    FOLLOW(D)={a,#}

     

    SELECT集:

    SELECT(A->Da)={b,a}

    SELECT(A->ε)={c,b,a,#}

    SELECT(C->aADC)={a}

    SELECT(C->ε)={#}

    SELECT(D->b)={b}

    SELECT(D->ε)={a,#}

     

    因为:

    SELECT(A->Da)∩SELECT(A->ε)≠∅

    所以此文法不为LL(1)文法。

    二、文法消除左递归之后的表达式文法是否是LL(1)文法?

    是。

    三、接2,如果是LL(1)文法,写出它的递归下降语法分析程序代码。

    void ParseE(){

      ParseT();

           ParseE'();

         }

    void ParseT()  {  

      ParseF();

      ParseT'();

    }

    void ParseE'()  {

      switch(lookahead):

        case +:

          MatchToken(+);

          ParseT();

          ParseE'();

          break;

        case #:

          break;

        case ):

          break;

        default:

          printf('synax error! ');

          exit(0);

    }

    void ParseF()  { 

      switch(lookahead):

        case (:

          MatchToken(();

          ParseE();
          MatchToken());

          break;

        case i:

          MatchToken(i);

          break;

        default:

          printf('synax error! ');

          exit(0);

    }

     

    void ParseT'()

    {

      switch(lookahead):

        case *:

          ParseF();

          MatchToken(*);

          ParseT'();

          break;

        case #:

          break;

        case ):

          break;

        case +:

          break;

        default:

          printf('synax error! ');

          exit(0);

    }

  • 相关阅读:
    hdu 2647 Reward
    hdu 2094 产生冠军
    hdu 3342 Legal or Not
    hdu 1285 确定比赛名次
    hdu 3006 The Number of set
    hdu 1429 胜利大逃亡(续)
    UVA 146 ID Codes
    UVA 131 The Psychic Poker Player
    洛谷 P2491消防 解题报告
    洛谷 P2587 [ZJOI2008]泡泡堂 解题报告
  • 原文地址:https://www.cnblogs.com/ccla/p/11887423.html
Copyright © 2011-2022 走看看