云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > 编译原理-LL(1)文法源代码(实验三)

编译原理-LL(1)文法源代码(实验三)

  • 62 次阅读
  • 3 次下载
  • 2025/5/4 0:40:12

开始读取一个非终结符V遍历所有产生式,查找左部是V的产生式添加一个删除空的标志为 true取出得到的一条产生式V*是不是有推导规则V*->空产生式右部第一个符号V*是终结符?将该终结符V*加入V的First集中空标志为真删除空,得到V的First集剩有非终结符?结束

2.计算非终结符的Follow集: Follow集合的具体构造算法如下:

(1)对于文法的开始符号S,置#于Follow(S)中;

(2)若A→αBβ是一个产生式,则把First(β)|{ε}加至Follow(B)中; (3)若A→αB是一个产生式,或A→αBβ是一个产生式而β ε(即ε∈First(β)),则把Follow(A)加至Follow(B)中。

连续使用上面的规则,直至每个集合Follow不再增大为止。

开始取得一个非终结符V查找产生式的右部含有V的产生式YV是不是最后一个字符NV后一个字符V*是否为终结符YY添加#到V的Follow集中YN是否遍历完所有右部含有V的产生式添加V*到V的Follow中Y将V*的First集加入到V的Follow集中是否有未求解过的非终结符N完成

3.预测分析控制程序的算法流程

输入要分析的字符串Y判断字符串是否正确N‘#’’E’进栈,当前终结符号送入a若产生式为A→A1A2…An,按逆序即[An…A2A1]入栈显示分析步骤读入下一符号显示栈中内容NY显示剩余输入串接受Y产生式右部为空?A∈Vt?YYA=‘a’?N匹配字符串?NNA=‘#’?YN产生式不存在?Y显示产生式NY出错出错

LL(1)文法(源代码) #include \#include \

#define MaxRuleNum 8 #define MaxVnNum 5 #define MaxVtNum 5

#define MaxStackDepth 20 #define MaxPLength 20 #define MaxStLength 50

struct pRNode /*产生式右部结构*/ {

int rCursor;

struct pRNode *next; };

struct pNode {

int lCursor;

int rLength; /*右部长度*/

struct pRNode *rHead; /*右部结点头指针*/ };

char Vn[MaxVnNum + 1]; /*非终结符集*/ int vnNum;

char Vt[MaxVtNum + 1]; /*终结符集*/ int vtNum;

struct pNode P[MaxRuleNum]; int PNum;

char buffer[MaxPLength + 1]; char ch;

char st[MaxStLength]; /*要分析的符号串*/

struct collectNode {

int nVt;

struct collectNode *next; };

struct collectNode* first[MaxVnNum + 1]; /*first集*/ struct collectNode* follow[MaxVnNum + 1]; /*follow集*/

搜索更多关于: 编译原理-LL(1)文法源代码(实验三) 的文档
  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

开始读取一个非终结符V遍历所有产生式,查找左部是V的产生式添加一个删除空的标志为 true取出得到的一条产生式V*是不是有推导规则V*->空产生式右部第一个符号V*是终结符?将该终结符V*加入V的First集中空标志为真删除空,得到V的First集剩有非终结符?结束 2.计算非终结符的Follow集: Follow集合的具体构造算法如下: (1)对于文法的开始符号S,置#于Follow(S)中; (2)若A→αBβ是一个产生式,则把First(β)|{ε}加至Follow(B)中; (3)若A→αB是一个产生式,或A→αBβ是一个产生式而β ε(即ε∈First(β)),则把Follow(A)加至Follow(B)中。 连续使用上面的规则,直至每个集合Follow不再增大为止。 开始取得一个非终结符V查找产生式的右

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com