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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

语法分析代码Word文件下载.docx

1、T FTF idE +TE如果输入串有错误,则在输出中要体现是跳过输入串的某些记号了,还是弹栈,弹出某个非终结符或者是终结符了,同时给出相应的出错提示信息。比如:idid*id对应的出错信息是:输入串跳过记号id,用户多输入了一个id;id*id对应的出错信息是:弹栈,弹出非终结符F,用户少输入了一个id(id+id对应的出错信息是:弹栈,弹出终结符 ) ,用户少输入了一个右括号(或者说,括号不匹配) 有余力的同学可进一步考虑如下扩展: 1.将递归下降方法和非递归预测分析方法都实现 2.在语法分析的过程中调用前两次上机的结果,即利用词法分析器来返回一个记号给语法分析器。 3.编写First和F

2、ollow函数,实现其求解过程。*/#includedos.hstdlib.hstring.hchar a50 ,b50;char ch;int n1,i1=0,flag=1,n=5,signal=0;int total=0;/*步骤计数器*/int E();int T();int E1();/*Eint T1();/*Tint F();void input();void input1();void main() /*递归分析*/ int f,j=0; printf(请输入字符串(长度TEtt,total);total+; flag=1; input(); input1(); if (i1=0

3、) while (ch=+|ch=*) if (ch=) / +i bi1=ch;printf(%dt? flag=0;input();input1(); printf(串首部多输入了一个+! ch=a+i1;) / *i串首部多输入了一个*! f=T(); if (f=0) return(0); t=E1(); if (t=0) return(0); else return(1);int T()%dtT-FT f=F(); t=T1();int E1() if(ch= bi1=ch; printf(%dtE-+TEt flag=0; input(); ch=a+i1; if (ch=) /

4、i+i bi1=ch; flag=0; printf(少输入了一个i! ch=a+i1; ) / i+*i f=T(); if (f=0) return(0); t=E1(); if (t=0) return(0); else return (1); tt return(1);int T1() int f,t;) %dtT*FT) / i*i) / i*+i f=F(); t=T1(); if (t=0) return(0); else return(1); ai1=ch;int F() int f;() %dtF-(E)ttsignal=1; f=E(); if(ch=) bi1=ch; flag=0; ch=a+i1; signal=0; else printf(缺少右括号! / return(0); /考虑容忍没有右)的情况 else if(ch=iitt&signal)缺少左括号!多输入了一个i! else printf(/return(0);void input() int j=0; for (;j=i1-flag;j+) printf(,bj); /*输出分析串*/%ctt,ch); /*输出分析字符*/ void input1() int j; for (j=i1+1-flag;n1;,aj); /*输出剩余字符*/

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2