zoukankan      html  css  js  c++  java
  • 11、LL(1)文法的判断,递归下降分析程序

    1. 文法 G(S):

    (1)S -> AB

    (2)A ->Da|ε

    (3)B -> cC

    (4)C -> aADC |ε

    (5)D -> b|ε

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

     

    2.(上次作业)消除左递归之后的表达式文法是否是LL(1)文法?

     

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

    E()

        {T();

           E'();

         }

    E'()

    T()

    T'()

    F()

     

     4.加上实验一的词法分析程序,形成可运行的语法分析程序,分析任意输入的符号串是不是合法的表达式。

    --------------------------------------------------------------------------------------------------------------------------------------------

    解:

    1、

    FIRST集

    FIRST(AB)={b,a,c}

    FIRST(Da)={b,a}

    FIRST(ε)={ε}

    FIRST(cC)={c}

    FIRST(aADC)={a}

    FIRST(b)={b}

     Follow集

    Follow(S)={c,b,a}

    Follow(A)={a,b,c,#}

    Follow(B)={a,b,c}

    Follow(C)={#}

    Follow(D)={#,a}

     Select集

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

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

     

    2、

           SELECT(E-> +TE') =  { + }

      SELECT(E' -> ɛ) = {  ) , # }

      SELECT(T-> *FT' ) ={ * }

      SELECT(T -> ɛ) = {  + , ) , # }

      SELECT(F -> (E) ) = { ( }

      SELECT(F -> i ) = { i } 

           SELECT(E-> +TE') ∩ SELECT(E' -> ɛ) = ∅

      SELECT(T-> *FT' ) ∩ SELECT(T -> ɛ) = ∅

      SELECT(F -> (E) ) ∩ SELECT(F -> i ) = ∅

    ∴    消除左递归后的文法是 LL(1)文法

    3、

    void ParseE(){

             if(lookahead==’(’ || lookahead==’i’){

               ParseT();

               ParseE’();

        }else{
               printf(“syntax error ”);

               exit(0);

        }

      }

       void ParseE’(){

        switch(lookahead){
               case ’+’:

                      MatchToken(’+’);

                      ParseT();

                      ParseE’();

                      break;

               case ’)’,’#’:

                      break;

               default:

                      printf(“syntax error ”);

                      exit(0);

          }

      }

       void ParseT(){

        if(lookahead==’(’ || lookahead==’i’ ){
               ParseF();

               ParseT’();

        } else{
               printf(“syntax error ”);

               exit(0);

        }

      }

       void ParseT’(){

        switch(lookahead){
               case ’*’:

                      MatchToken(’*’);

                      ParseF();

                      ParseT’();

                      break;

               case ’+’,’)’,’#’:

                      break;

               default:

                      printf(“syntax error ”);

                      exit(0);

        }

       }

       void ParseF(){

        switch(lookahead){
               case ’(’:

                      MatchToken( ’(’);

                      ParseE();

                      MatchToken(’)’ );

                      break;

               case ’i’:

                      MatchToken(’i’);

                      break;

               default:

                      printf(“syntax error ”);

                      exit(0);

        }

      }

  • 相关阅读:
    LeetCode Subsets II
    LeetCode Rotate Image
    LeetCode Palidrome Number
    LeetCode Generate Parentheses
    LeetCode Maximum Subarray
    LeetCode Set Matrix Zeroes
    LeetCode Remove Nth Node From End of List
    Linux Loop设备 使用
    Linux 文件系统大小调整
    LeetCode N-Queens II
  • 原文地址:https://www.cnblogs.com/dyun3/p/11909676.html
Copyright © 2011-2022 走看看