ImageVerifierCode 换一换
格式:DOCX , 页数:29 ,大小:19.29KB ,
资源ID:15857246      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/15857246.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(LL1语法分析c++实现first集follow集分析表分析栈Word格式文档下载.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

LL1语法分析c++实现first集follow集分析表分析栈Word格式文档下载.docx

1、char VnMaxVnNum + 1; /*非终结符集*/int vnNum;char VtMaxVtNum + 1; /*终结符集*/int vtNum;struct pNode PMaxRuleNum;int PNum;char bufferMaxPLength + 1;char ch;char stMaxStLength; /*要分析的符号串*/struct collectNode int nVt; struct collectNode *next;struct collectNode* firstMaxVnNum + 1; /*first集*/struct collectNode*

2、followMaxVnNum + 1; /*follow集*/int analyseTableMaxVnNum + 1MaxVtNum + 1 + 1;int analyseStackMaxStackDepth + 1; /*分析栈*/int topAnalyse; /*分析栈顶*/void Init();/*初始化*/int IndexCh(char ch);void InputVt(); /*输入终结符*/void InputVn();/*输入非终结符*/void ShowChArray(char* collect, int num);/*输出Vn或Vt的内容*/void InputP()

3、;/*产生式输入*/bool CheckP(char * st);/*判断产生式正确性*/void First(int U);void AddFirst(int U, int nCh); /*加入first集*/bool HaveEmpty(int nVn);void Follow(int V);/*计算follow集*/void AddFollow(int V, int nCh, int kind);void ShowCollect(struct collectNode *collect);/*输出first或follow集*/void FirstFollow();/*计算first和fol

4、low*/void CreateAT();/*构造预测分析表*/void ShowAT();/*输出分析表*/void Identify(char *st);void InitStack();void ShowStack();void Pop();void Push(int r);int main() char todo,ch; Init(); InputVn(); InputVt(); InputP(); getchar(); FirstFollow(); printf(所得first集为:); ShowCollect(first);所得follow集为: ShowCollect(follo

5、w); CreateAT(); ShowAT(); todo = y; while( = todo) n是否继续进行句型分析?(y / n): todo = getchar(); != todo & n= todo)n(y / n)? if( int i; InitStack();请输入符号串(以#结束) : ch = getchar(); i = 0;#= ch & i MaxStLength)n= ch) sti+ = ch; = ch & sti = ch; Identify(st); else 输入出错!nvoid Init() int i,j; vnNum = 0; vtNum =

6、0; PNum = 0; for(i = 0;= MaxVnNum; i+) Vni = 0= MaxVtNum; Vti = MaxRuleNum; Pi.lCursor = NULL; Pi.rHead = NULL; Pi.rLength = 0;= MaxPLength; bufferi = MaxVnNum; firsti = NULL; followi = NULL; for(j = 0; j = MaxVnNum + 1; j+) analyseTableij = -1;int IndexCh(char ch) int n; n = 0; /*is Vn?*/ while(ch

7、!= Vnn &= Vnn) n+; return 100 + n; /*is Vt?= Vtn &= Vtn) return n; return -1;void ShowChArray(char* collect) int k = 0;= collectk) %c , collectk+);void InputVn() int inErr = 1; int n,k; char ch; while(inErr)n请输入所有的非终结符,注意:请将开始符放在第一位,并以#号结束: ch = /*初始化数组*/ while(n MaxVnNum) Vnn+ = while(= ch) & (n Ma

8、xVnNum) -1 = IndexCh(ch) Vnn+ = ch; vnNum+; Vnn = /*以“#”标志结束用于判断长度是否合法*/ k = n; if( = (ch = getchar() ;n符号数目超过限制! inErr = 1; continue; /*正确性确认,正确则,执行下下面,否则重新输入*/ Vnk = ShowChArray(Vn);输入正确确认?(y/n): scanf(%c, &ch); = ch)录入错误重新输入! else inErr = 0;/*输入终结符*/void InputVt()n请输入所有的终结符,注意:以#号结束: MaxVtNum) Vtn+ = MaxVtNum) Vtn+ = ch; vtNum+; Vtn = Vtk = ShowChArray(Vt);void InputP() int i = 0, n,num; prin

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1