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集:
FIRST(A) → { a,b }
FIRST(Da) → { a,b }
FIRST(ε)→{ ε }
FIRST(cC)→{ a,c }
FIRST(b)→{ b }
FOLLOW集:
FOLLOW(S)→{ # }
FOLLOW(A)→{ a,b,c,# }
FOLLOW(B)→{ # }
FOLLOW(C)→{ # }
FOLLOW(D)→{ a,# }
SELECT集:
SELECT(A→Da)={b,a}
SELECT(A→ε)={a,b,c,#}
SELECT(B→cC)={c}
SELECT(C→aADC)={a}
SELECT(C→ε)={#}
SELECT(D→b)={b}
SELECT(D→ε)={a,#}
因为:SELECT(A→Da) ∩ SELECT(A→ε) ≠ Ø
所以G(S)不是 LL(1)文法。
2.(上次作业)消除左递归之后的表达式文法是否是LL(1)文法?
消除左递归后:
E → TE'
E' → +TE' | ε
T → FT'
T' → *FT' | ε
F → (E) | i
FIRST集:
FIRST(E) → { ( , i }
FIRST(E') → { +,ε }
FIRST(T) → { ( , i }
FIRST(T') → { *,ε }
FIRST(F) → { ( , i }
FOLLOW集:
FOLLOW(E) → { ) , # }
FOLLOW(E') → { ) , # }
FOLLOW(T) → { + , ) , # }
FOLLOW(T') → { + , ) , # }
FOLLOW(F) → { * , + , ) , # }
SELECT集:
SELECT(E→TE') → { ( , i }
SELECT(E'→+TE') → {+}
SELECT(E'→ε)= FIRST(ε)-{ ε } U FOLLOW(E') = FOLLOW(E') → { ) , # }
SELECT(T→FT') → { ( , i }
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)=∅
所以文法 G(S)是 LL(1)文法。
3.接2,如果是LL(1)文法,写出它的递归下降语法分析程序代码。
E()
{T();
E'();
}
E'()
T()
T'()
F()
SELECT集:
SELECT(E→TE') → { ( , i }
SELECT(E'→+TE') → {+}
SELECT(E'→ε)= FIRST(ε)-{ ε } U FOLLOW(E') = FOLLOW(E') → { ) , # }
SELECT(T→FT') → { ( , i }
SELECT(T'→*FT') → {*}
SELECT(T'→ε) → {+,),#}
SELECT(F→(E)) → { ( }
SELECT(F→i) → { i }
递归下降语法分析程序:
void ParseE() { switch (lookahead) { case '(','i': ParseT(); ParseE '(); break; default: print("syntax error \n"); exit(0); } } void ParseE'(){ switch(lookahead) { case '+': MatchToken('+'); ParseT(); ParseE '(); break; case ')','#': break; default: print("syntax error \n"); exit(0); } } void ParseT() { switch (lookahead) { case '(','i': ParseF(); ParseT '(); break; default: print("syntax error \n"); exit(0); } } void ParseT'(){ switch(lookahead){ case'*': MatchToken('*'); ParseF(); ParseT'(); break; case'+',')','#': break; default: print("syntax error \n"); exit(0); } } void ParseF(){ switch(lookahead){ case'(': MatchToken('('); ParseE(); MatchToken(')'); break; case'i': MatchToken('i'); break; default: print("syntax error \n"); exit(0); } }
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(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(S)是不 ...
- TINY语言采用递归下降分析法编写语法分析程序
目录 自顶向下分析方法 TINY文法 消左提左.构造first follow 基本思想 python构造源码 运行结果 参考来源:聊聊编译原理(二) - 语法分析 自顶向下分析方法 自顶向下分析方法: ...
- 编译原理-递归下降分析法 c程序部分的分析
实验三 语法分析程序实验 专业 商软2班 姓名 黄仲浩 学号 201506110166 一. 实验目的 编制一个部分文法分析程序. 二. 实验内容和要求 输入:源程序字符串 输出:正确 ...
随机推荐
- 记一次uboot中gunzip解压速度慢的问题排查
背景 在项目中需要用到解压功能,之前还记录了下,将uboot解压代码移植到另外的bootloader中时,碰到的效率问题.最终查明是cache的配置导致的. https://www.cnblogs.c ...
- ctf线下赛中检测外来IP的shell脚本
该脚本可用于ctf线下赛中,用来检测攻击IP的接入,及时做出响应. #!/bin/bash #写自己队的ip ipA="172.22.60.230" ipB="172.2 ...
- EntityFramework Core 3多次Include导致查询性能低之解决方案
前言 上述我们简单讲解了几个小问题,这节我们再来看看如标题EF Core中多次Include导致出现性能的问题,废话少说,直接开门见山. EntityFramework Core 3多次Include ...
- 使用Python爬取、清洗并分析前程无忧的大数据职位
爬取前程无忧的数据(大数据职位) # -*- coding: utf-8 -*- """ Created on Wed Nov 1 14:47:27 2019 @auth ...
- Github Fork 缎带.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title&g ...
- luogu P2863 [USACO06JAN]牛的舞会The Cow Prom |Tarjan
题目描述 The N (2 <= N <= 10,000) cows are so excited: it's prom night! They are dressed in their ...
- Apache Maven从入门到升天
喜欢就点个赞呗! GitHub项目JavaHouse同步收录 1 引入 在日常 Java 开发中,Maven 应该是必不可少的一个工具了,当然也有人使用 Gradle 的.那么 Maven 究竟是个啥 ...
- Dubbo初步
Dubbo 介绍 : Dubbo 是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的RPC 实现服务的输出和输入功能,可以和 Spring 框架无缝集成.Dubbo 框架,是基于容器 ...
- 【解决】image ... could not be accessed on a registry to record its digest.
[问题]image jmdiservice:1206 could not be accessed on a registry to record its digest. Each node will ...
- LightOJ1284 Lights inside 3D Grid (概率DP)
You are given a 3D grid, which has dimensions X, Y and Z. Each of the X x Y x Z cells contains a lig ...