电脑桌面
添加小米粒文库到电脑桌面
安装后可以在桌面快捷访问

自顶向下的语法分析:LL分析法

自顶向下的语法分析:LL分析法_第1页
1/23
自顶向下的语法分析:LL分析法_第2页
2/23
自顶向下的语法分析:LL分析法_第3页
3/23
《编译原理》课程实验 实验三:自顶向下的语法分析:LL(1)分析法 1、实验目的:用LL(1)分析法分析高级语言表达式。了解LL(1)分析器的工作过程 2、实验要求: 文法:无二义性的算术表达式的文法 (1)把词法分析作为语法分析的子程序实现(5 分) (2)独立的语法分析程序(4 分) (3)对表达式文法消除左递归、构造LL(1)分析表 (4)LL(1)分析表可以直接输入(4 分),也可以用程序实现(5 分) (5)给一个表达式,给出分析过程(分析栈、输入串、所用规则)(4 分) (6)生成一个棵语法树(5 分)用二叉树的形式表示出来 LL(1)分析表算法: (1) 构造所有侯选式的FIRST 集合,构造所有非终结符的FOLLOW 集合 (2) 对于文法G 的每个产生式A→α ,执行(3)和(4) (3) 对于每个终结符a∈FIRST(α ),把A→α 加至M[A][a] (4) 若ε ∈FIRST(α ),则对于每个终结符 b∈FOLLOW (A),把A→α 加至M[A][b] (5) 把所有未定义的M[A][c] 标上“出错标志”(c∈VT) /*--------------------声明-----------------------*/ /* 阅读程序请从LL1.h开始。 补充: 程序存在问题: (1) follow集不能处理:U->xVyVz的情况; (2) 因本人偷懒,本程序为加入文法判断,故 输入的文法必须为LL(1)文法; (3) 您可以帮忙扩充:消除左递归,提取公因子等函数 (4) „„ */ /*-----------------------------------------------*/ #include "LL1.h" /*-------------------main function--------------------*/ void main(void) { char todo,ch; Init(); InputVn(); InputVt(); InputP(); getchar(); FirstFollow(); printf("所得first集为:"); ShowCollect(first); printf("所得follow集为:"); ShowCollect(follow); CreateAT(); ShowAT(); todo = 'y'; while('y' == todo) { printf("\n是否继续进行句型分析?(y / n):"); todo = getchar(); while('y' != todo && 'n' != todo) { printf("\n(y / n)? "); todo = getchar(); } if('y' == todo) { int i; InitStack(); printf("请输入符号串(以 #结束) : "); ch = getchar(); i = 0; while('#' != ch && i < MaxStLength) { if(' ' != ch && '\n' != ch) { st[i++] = ch; } ch = getchar(); } if('#' == ch && i < MaxStLength) { st[i] = ch; I...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。
3、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。

碎片内容

自顶向下的语法分析:LL分析法

确认删除?
VIP
微信客服
  • 扫码咨询
会员Q群
  • 会员专属群点击这里加入QQ群
客服邮箱
回到顶部