zoukankan      html  css  js  c++  java
  • 表达式语法分析——预测分析法

                             表达式语法分析——预测分析法
    

    Time Limit: 1000 ms Memory Limit: 65536 KiB

    Problem Description
    预测分析法是自顶向下分析的一种方法,一个预测分析程序是由三个部分组成:
    (1) 预测分析程序

    (2) 先进后出栈

    (3) 预测分析表

    现给出表达式文法:

    E→TG

    G→+TG | ε

    T→FS

    S→*FS | ε

     F→(E) | i
    

    该表达式文法是LL(1)文法,其预测分析表为:

    请根据该预测分析表构造预测分析程序,完成对表达式的语法分析,对给定的输入串,判断其是否为合法表达式,给出所使用的产生式序列。

    Input

    给定输入串(长度不超过50个符号,以#号结束,符号保证是终结符或#)。

    例如:

    i+i*i# 是合法表达式

    i+i*(i+i)# 是合法表达式

    ii+i*i# 不是合法表达式

    i*(i+i# 不是一个合法的表达式。

    Output
    要求输出分析过程中使用的所有产生式,产生式按使用顺序各占一行,每行有两个数据,使用顺序号(从1开始编号)及产生式本身,中间用一个空格分开,最后一行表示语法分析是否成功结束,如果成功分析结束输出acc!,表示该输入串是合法表达式,否者输出error!,表示该输入串不是合法表达式。
    注:其中^符号代表文法中的ε符号。
    针对输入串i+i*i#,因为分析过程使用了11次产生式,且该输入串是合法表达式,输出如下:
    1 E->TG

    2 T->FS

    3 F->i

    4 S->^

    5 G->+TG

    6 T->FS

    7 F->i

    8 S->*FS

    9 F->i

    10 S->^

    11 G->^

    acc!

    针对输入串i*(i+i#,因为分析过程使用了14次产生式后,发现语法错误,该输入串不是合法表达式,输出如下:

    1 E->TG

    2 T->FS

    3 F->i

    4 S->*FS

    5 F->(E)

    6 E->TG

    7 T->FS

    8 F->i

    9 S->^

    10 G->+TG

    11 T->FS

    12 F->i

    13 S->^

    14 G->^

    error!

    Sample Input
    i+i*i#
    Sample Output
    1 E->TG
    2 T->FS
    3 F->i
    4 S->^
    5 G->+TG
    6 T->FS
    7 F->i
    8 S->*FS
    9 F->i
    10 S->^
    11 G->^
    acc!
    Hint

    Source

    #include<iostream>
    #include<stdio.h>
    using namespace std;
    int main()
    {
        string a[200][200];
        string b,s;
        b="#E";
        int i=2,l=1;
        a['E']['i']="E->TG";
        a['E']['(']="E->TG";
        a['G']['+']="G->+TG";
        a['G'][')']="G->^";
        a['G']['#']="G->^";
        a['T']['i']="T->FS";
        a['T']['(']="T->FS";
        a['S']['+']="S->^";
        a['S']['*']="S->*FS";
        a['S'][')']="S->^";
        a['S']['#']="S->^";
        a['F']['i']="F->i";
        a['F']['(']="F->(E)";
        cin>>s;
        int sl=s.length(),sl1=0;
        while(b[i-1]!='#'||s[sl1]!='#')
        {
            if(b[i-1]>='A'&&b[i-1]<='Z')
            {
            if(a[b[i-1]][s[sl1]]!="")
            {
                cout<<l++<<" "<<a[b[i-1]][s[sl1]]<<endl;
                if(b[i-1]=='E'&&(s[sl1]=='i'||s[sl1]=='('))
                    {
                        b[i-1]='G';
                        b[i++]='T';
                    }
                    else if(b[i-1]=='G'&&s[sl1]=='+')
                    {
                      b[i-1]='G';
                      b[i++]='T';
                      b[i++]='+';
    
                    }
                    else if(b[i-1]=='G'&&(s[sl1]==')'||s[sl1]=='#'))
                    {
                      i--;
                    }
                    else if(b[i-1]=='T'&&(s[sl1]=='i'||s[sl1]=='('))
                    {
                        b[i-1]='S';
                        b[i++]='F';
                    }
                    else if(b[i-1]=='S'&&s[sl1]=='*')
                    {
                       b[i-1]='S';
                       b[i++]='F';
                       b[i++]='*';
                    }
                    else if(b[i-1]=='S'&&(s[sl1]=='+'||s[sl1]==')'||s[sl1]=='#'))
                    {
                       i--;
                    }
                    else if(b[i-1]=='F'&&s[sl1]=='i')
                    {
                       b[i-1]='i';
                    }
                    else if(b[i-1]=='F'&&s[sl1]=='(')
                    {
                       b[i-1]=')';
                       b[i++]='E';
                       b[i++]='(';
                    }
            }
            else
            {
                cout<<"error!"<<endl;
                break;
            }
            }
            else
            {
                if(b[i-1]==s[sl1])
                {
                    i--;
                    sl1++;
                }
                else
              {
                  cout<<"error!"<<endl;
              break;
              }
            }
        }
        if(b[i-1]=='#'&&s[sl1]=='#')
        {
          cout<<"acc!"<<endl;
        }
    
    }
  • 相关阅读:
    php://input,$_POST,$HTTP_RAW_POST_DATA区别
    使用print2flash开发在线文档
    [转] 一百本名著中的一百句话
    [转]PHP经验——PHPDoc PHP注释的标准文档
    .htaccess是什么?.htaccess几个简单应用
    帝国CMS系统结合项图文教程
    帝国cms文章内容tags关键词设置调用方法以及tags静态化
    如何在Apache中配置多端口访问
    USER-AGENT是什么
    关于js的几道经典题(作用域、原型链等)自己做的
  • 原文地址:https://www.cnblogs.com/CCCrunner/p/11781729.html
Copyright © 2011-2022 走看看