算符优先文法的判别

算符优先文法的判别

ID:14227407

大小:46.50 KB

页数:18页

时间:2018-07-27

算符优先文法的判别_第1页
算符优先文法的判别_第2页
算符优先文法的判别_第3页
算符优先文法的判别_第4页
算符优先文法的判别_第5页
资源描述:

《算符优先文法的判别》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、算符优先文法的判别//算符优先文法的判别//#include#include#includetypedefstruct{charR;charr;intflag;}array;typedefstruct{charE;chare;}charLode;typedefstruct{charLode*base;inttop;}charstack;charstr[80][80],arr[80][80],brr[80][80];arrayF[20];intm,kk,p,ppp,FF=1;charr[10];intcrr[20][20],FLAG=

2、0;charccrr1[1][20],ccrr2[20][1];voidInitstack(charstack&s)//定义栈{s.base=newcharLode[20];s.top=-1;}voidpush(charstack&s,charLodew){s.top++;s.base[s.top].E=w.E;s.base[s.top].e=w.e;}voidpop(charstack&s,charLode&w){w.E=s.base[s.top].E;w.e=s.base[s.top].e;s.top--;}intIsEmpty(charstacks){if(s.top==-1)retur

3、n1;elsereturn0;}intIsLetter(charch){if(ch>='A'&&ch<='Z')return1;elsereturn0;}//judge1是判断是否是算符文法:若产生式中含有两个相继的非终结符则不是算符文法intjudge1(intn){intj=3,flag=0;for(inti=0;i<=n;i++)while(str[i][j]!=''){chara=str[i][j];charb=str[i][j+1];if(IsLetter(a)&&IsLetter(b)){flag=1;break;}elsej++;}if(flag==1)return0;els

4、ereturn1;}//judge2是判断文法G是否为算符优先文法:若不是算符文法或若文法中含空字或终结符的优先级不唯一则不是算符优先文法voidjudge2(intn){for(inti=0;i<=n;i++)if(str[i][3]=='~'

5、

6、judge1(n)==0

7、

8、FLAG==1)//'~'代表空字{cout<<"文法G不是算符优先文法!"<n)cout<<"文法G是算符优先文法!"<

9、ti=0;i

10、(str[i][j]!=''){c=str[i][j];if(IsLetter(c)==0){if(!search1(r,kk,c))r[kk]=c;kk++;//r数组用来存放终结符}j++;}}m=0;for(i=0;i

11、ag=1;break;}}voidFirstVT(intn)//求FirstVT{charstacksta;charLodew;inti=0;Initstack(sta);while(i<=n){intk=3;w.E=str[i][0];chara=str[i][k];charb=str[i][k+1];if(!IsLetter(a))//产生式的后选式的第一个字符就是终结符的情况{w.e=a;p

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。