编译原理实验二:LL(1)语法分析器

一、实验要求    1. 提取左公因子或消除左递归(实现了消除左递归)  2. 递归求First集和Follow集  其它的只要按照课本上的步骤顺序写下来就好(但是代码量超多...),下面我贴出实验的一些关键代码和算法思想。二、基于预测分析表法的语法分析  2.1 代码结构    2.1.1 Grammar类     功能:主要用来处理输入的文法,包...
摘要由CSDN通过智能技术生成

一、实验要求

  

  1. 提取左公因子或消除左递归(实现了消除左递归)

  2. 递归求First集和Follow集

  其它的只要按照课本上的步骤顺序写下来就好(但是代码量超多...),下面我贴出实验的一些关键代码和算法思想。

二、基于预测分析表法的语法分析

  2.1 代码结构

    2.1.1  Grammar类

       功能:主要用来处理输入的文法,包括将文法中的终结符和非终结符分别存储,检测直接左递归和左公因子,消除直接左递归,获得所有非终结符的First集,Follow集以及产生式的Select集。

#ifndef GRAMMAR_H
#define GRAMMAR_H
#include <string>
#include <cstring>
#include <iostream>
#include <vector>
#include <set>
#include <iomanip>
#include <algorithm>
using namespace std;
const int maxn = 110;

//产生式结构体 
struct EXP{
    char left;      //左部
    string right;   //右部
};

class Grammar
{
    public:
        Grammar();               //构造函数
        bool isNotTer(char x);   //判断是否是终结符
        int  getTer(char x);     //获取终结符下标 
        int  getNonTer(char x);  //获取非终结符下标
        void getFirst(char x);   //获取某个非终结符的First集
        void getFollow(char x);  //获取某个非终结符的Follow集
        void getSelect(char x);  //获取产生式的Select集
        void input();            //输入文法
        void scanExp();          //扫描输入的产生式,检测是否有左递归和左公因子 
        void remove();           //消除左递归 
        void solve();            //处理文法,获得所有First集,Follow集以及Select集
        void display();          //打印First集,Follow集,Select集
        void debug();            //用于debug的函数 
        ~Grammar();               //析构函数 
    protected:
        int cnt;                 //产生式数目
        EXP exp[maxn];           //产生式集合
        set<char> First[maxn];   //First集
        set<char> Follow[maxn];  //Follow集
        set<char> Select[maxn];  //select集
        vector<char> ter_copy;   //去掉$的终结符
        vector<char> ter;        //终结符
        vector<char> not_ter;    //非终结符
};
#endif

       2.1.2  AnalyzTable类

    功能:得到预测分析表,判断输入的文法是否是LL(1)文法,用预测分析表法判断输入的符号串是否符合刚才输入的文法,并打印出分析过程。

#ifndef ANALYZTABLE_H
#define ANALYZTABLE_H
#include "Gramma.h"
class AnalyzTable:public Gramma
{
    public:
        AnalyzTable();
        void getTable();          //得到分析表
        void judge();             //判断是否是LL(1)文法 
        void analyExp(string s);  //分析输入串 
        void displayTable();      //打印表
        void inputString();       //输入符号串 
        ~AnalyzTable();
    protected:
        string s;                 //符号串
        vector<char> stack;       //分析栈
        vector<char> left;        //剩余输入串
        int detect[maxn][maxn];   //检测表
        int table[maxn][maxn];    //预测分析表
};
#endif

  2.2 记号和规定

    • 非终结符:大写字母'A'~'Z'

    • 终结符:除大写字母之外的所有字符

    • 空串:$

    • 符号栈终止符:#

    • 规定第一个产生式的左边那个非终结符就是开始符号

    • 输入的产生式需要分开写(比如A

  • 3
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值