编译原理:LL(1)文法的判断,递归下降分析程序
1. 文法 G(S):
(1)S -> AB
(2)A ->Da|ε
(3)B -> cC
(4)C -> aADC |ε
(5)D -> b|ε
验证文法 G(S)是不是 LL(1)文法?
FIRST(Da)={b,a} FIRST(ε)={ε} FIRST(aADC)={a} FIRST(b)={b} FOLLOW(A)={c,b,a,#} FOLLOW(C)={#,} FOLLOW(D)={a,#} SELECT(A->Da)=FIRST(Da)={b,a} SELECT(A->ε)=FIRST(ε)-{ε}UFOLLOW(A)=FOLLOW(A)={c,b,a,#} ∵ SELECT(A->Da) ∩ SELECT(A->ε) ≠ Ø ∴ G(S)不是 LL()文法。
2.(上次作业)消除左递归之后的表达式文法是否是LL(1)文法?
解析:
表达式文法为:
(1)E->TE'
(2)E'->+TE' | ε
(3)T->FT'
(4)T'->*FT' | ε
(5)F->(E) | i
FIRST(+TE')={+} FIRST(ε)={ε} FIRST(*FT')={*} FIRST((E))={ ( } FIRST(i)={i} FOLLOW(E')={ ),# } FOLLOW(T')={+,),#} FOLLOW(F)={*,+,),#} SELECT(E'->+TE')=FIRST(+TE')={+} SELECT(E'->ε)=FIRST(ε)-{ε}UFOLLOW(E')=FOLLOW(E')={ ),# } SELECT(T'->*FT')=FIRST(*FT')={*} SELECT(T'->ε)=FIRST(ε)-{ε}UFOLLOW(T')=FOLLOW(T')={ +,),# } SELECT(F->(E))=FIRST((E))={ ( } SELECT(F->i)=FIRST(i)={i} ∵ SELECT(E'->+TE') ∩ SELECT(E'->ε) = Ø SELECT(T'->*FT') ∩ SELECT(T'->ε) = Ø SELECT(F->(E)) ∩ SELECT(F->i) = Ø 所以此表达式文法是LL()文法。
3.接2,如果是LL(1)文法,写出它的递归下降语法分析程序代码。
E()
{T();
E'();
}
E'()
T()
T'()
F()
解析:
SELECT集: SELECT(E->TE')=FIRST(TE')={ (, i } SELECT(E'->+TE')=FIRST(+TE')={+} SELECT(E'->ε)=FIRST(ε)-{ε}UFOLLOW(E')=FOLLOW(E')={ ),# } SELECT(T->FT')=FIRST(FT')={ (,i } SELECT(T'->*FT')=FIRST(*FT')={*} SELECT(T'->ε)=FIRST(ε)-{ε}UFOLLOW(T')=FOLLOW(T')={ +,),# } SELECT(F->(E))=FIRST((E))={ ( } SELECT(F->i)=FIRST(i)={i} 递归下降语法分析程序: void ParseE(){ switch(lookahead){ case '(','i': ParseT(); ParseE'(); break; default: print("syntax error \n"); exit(); } } void ParseE'(){ switch(lookahead){ case '+': MatchToken('+'); ParseT(); ParseE'(); break; case ')','#': break; default: print("syntax error \n"); exit(); } } void ParseT(){ switch(lookahead){ case '(','i': ParseF(); ParseT'(); break; default: print("syntax error \n"); exit(); } } void ParseT'(){ switch(lookahead){ case '*': MatchToken('*'); ParseF(); ParseT'(); break; case '+',')','#': break; default: print("syntax error \n"); exit(); } } void ParseF(){ switch(lookahead){ case '(': MatchToken('('); ParseE(); MatchToken(')'); break; case 'i': MatchToken('i'); break; default: print("syntax error \n"); exit(); }
4.加上实验一的词法分析程序,形成可运行的语法分析程序,分析任意输入的符号串是不是合法的表达式。
编译原理:LL(1)文法的判断,递归下降分析程序的更多相关文章
- 作业十一——LL(1)文法的判断,递归下降分析程序
作业十一——LL(1)文法的判断,递归下降分析程序 判断是否为LL(1)文法 选取有多个产生式的求select,只有一条产生式的无需求select 同一个非终结符之间求交集,全部判断为空后则为LL(1 ...
- 编译原理 #02# 简易递归下降分析程序(js实现)
// 实验存档 截图: 代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"&g ...
- 编译原理之LL(1)文法的判断,递归下降分析程序
1. 文法 G(S): (1)S -> AB (2)A ->Da|ε (3)B -> cC (4)C -> aADC |ε (5)D -> b|ε 验证文法 G(S)是不 ...
- 十一次作业——LL(1)文法的判断,递归下降分析程序
1. 文法 G(S): (1)S -> AB (2)A ->Da|ε (3)B -> cC (4)C -> aADC |ε (5)D -> b|ε 验证文法 G(S)是不 ...
- LL(1)文法的判断,递归下降分析程序
1. 文法 G(S): (1)S -> AB (2)A ->Da | ε (3)B -> cC (4)C -> aADC | ε (5)D -> b | ε 验证文法 G ...
- 第十一次作业 LL(1)文法的判断,递归下降分析程序
1. 文法 G(S): (1)S -> AB (2)A ->Da|ε (3)B -> cC (4)C -> aADC |ε (5)D -> b|ε 验证文法 G(S)是不 ...
- 第十一次 LL(1)文法的判断,递归下降分析程序
1. 文法 G(S): (1)S -> AB (2)A ->Da|ε (3)B -> cC (4)C -> aADC |ε (5)D -> b|ε 验证文法 G(S)是不 ...
- 编译原理-递归下降分析法 c程序部分的分析
实验三 语法分析程序实验 专业 商软2班 姓名 黄仲浩 学号 201506110166 一. 实验目的 编制一个部分文法分析程序. 二. 实验内容和要求 输入:源程序字符串 输出:正确 ...
- TINY语言采用递归下降分析法编写语法分析程序
目录 自顶向下分析方法 TINY文法 消左提左.构造first follow 基本思想 python构造源码 运行结果 参考来源:聊聊编译原理(二) - 语法分析 自顶向下分析方法 自顶向下分析方法: ...
随机推荐
- Mac 常见命令行
1. unrar解压rar文件 1.1 安装命令:brew install unrar 1.2 解压文件:unrar x test.rar 2. 创建文件夹:mkdir 文件夹名 3. 删除文件夹: ...
- 【Mood】八上期末考
Final exam Day -30 平姐在班会上突然就说了一句,离期末考只有一个月了. 刚从体育节的气氛中脱离出来的我想了想,好像还真的是诶. 又努力地去想了想,好像不太慌张呢. Final ex ...
- 使用Properties配置文件进行配置读取
#使用Properties配置文件进行配置读取: 例如:有一个配置文件的内容如下: # setting.properties last_open_file=/data/hello.txt auto_s ...
- 使用MySQL练习增删改查时因为版本问题出现连接错误
使用MySQL练习增删改查时出现连接错误,错误提示如下: 2020-02-19 19:53:51.088 ERROR 16328 --- [reate-249798694] com.alibaba.d ...
- MySQL数据库无完整备份删库,除了跑路还能怎么办?
1.背景 前段时间,由于运维同事的一次误操作,清空了内网核心数据库,导致了公司内部管理系统长时间不可用,大量知识库内容由于没有备份险些丢失. 结合这两天微盟的删库跑路事件,我们可以看到,数据库的备份与 ...
- ubuntu16.04安装库、插件报错:
安装一些插件.库,遇到报错 Could not fetch URL https://pypi.org/simple/pytest-pycodestyle/: There was a problem c ...
- Java Opencv 实现 中值滤波器
原理 Note 以下原理来源于Richard Szeliski 的著作 Computer Vision: Algorithms and Applications 以及 Learning OpenCV ...
- A. Reorder the Array
You are given an array of integers. Vasya can permute (change order) its integers. He wants to do it ...
- 分享一个快速审查js操作Dom的css
第一步 打开开发者工具第二步 打开 Sources 面板第三步 执行用户操作让对象可见(例如鼠标悬停)第四步 在元素可见的时候按下 F8(与“暂停脚本执行”按钮相同)第五步 点击开发者工具左上角的“选 ...
- 通过mockjs来制作假数据
需用用到的模块为express和mockjs //导入模块开启服务器模块 const express=require('express') //导入假数据模块 const mockjs=require ...