消除左递归文法
来源:互联网 发布:淘宝 疯马皮 编辑:程序博客网 时间:2024/05/01 01:02
无法根据左递归文法编写出递归下降分析器,因而把左递归文法等价变换为非左递归文法至关重要,以下是变换的算法:
1、消除直接左递归
原文法: E --> E a1 | E a2 | ... | E an | b1 | b2 | ... | bn
消除后: E --> b1 E' | b2 E' | ... | bn E'
E'--> a1 E' | a2 E' | ... | an E' | epsilon
2、消除间接左递归
a) 把所有非终结符号按一定序列排序为E1, E2, ... En;
b) for i=1 to n do /*依次处理每个非终结符号*/
for j=1 to i-1 do /*处理第1个到i-1个*/
若Ei --> Ej r
则改为Ei --> S1 r | S2 r | ... | Sk r
其中Ej --> S1 | S2 | ... | Sk
c) 对Ei消除直接左递归。
注:非终结符的排列顺序不同,结果可能不同。
3、去掉无用符号和无用产生式
转:http://blog.csdn.net/goncely/article/details/627569
0 0
- 消除左递归文法
- 消除左递归文法
- 消除文法的左递归
- 消除文法的左递归
- 消除文法中一切左递归算法
- 消除文法左递归-编译原理
- 编译原理(三) 消除文法左递归
- 文法左递归的消除(直接左递归和间接左递归)
- 编译原理(三) 消除文法的左递归
- 编译原理之消除算术表达式文法的左递归
- 编译原理(三) 消除文法的左递归
- 2-型文法消除左递归算法(上下文无关文法)
- 左递归文法
- 左递归文法 不太懂
- 左递归文法笔记
- 左递归文法
- 自上而下的语法分析,LL(1)文法(消除左递归,提取左因子)
- 编译原理-左递归文法
- 【算法分析】之从次小生成树看LCA
- X5资料
- HDU2512 一卡通大冒险【斯特灵数,贝尔数】
- C#用DataTable实现Group by数据统计
- 欢迎使用CSDN-markdown编辑器
- 消除左递归文法
- 如何用网线实现两台电脑之间的文件共享
- OpenGL入门学习
- codeforces 527D Clique Problem
- 九度OJ 1083 特殊乘法
- DownloadProvider介绍
- 代码块 注意事项
- node-socket实现web的即时聊天系统
- C++第三方程序包在不同操作系统下的使用