- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
#includestdlib.h
#includestdio.h
#includestring.h
/*******************************************/
int count=0; /*分解的产生式的个数*/
int number; /*所有终结符和非终结符的总数*/
char start; /*开始符号*/
char termin[50]; /*终结符号*/
char non_ter[50]; /*非终结符号*/
char v[50]; /*所有符号*/
char left[50]; /*左部*/
char right[50][50]; /*右部*/
char first[50][50],follow[50][50]; /*各产生式右部的FIRST和左部的FOLLOW集合*/
char first1[50][50]; /*所有单个符号的FIRST集合*/
char select[50][50]; /*各单个产生式的SELECT集合*/
char f[50],F[50]; /*记录各符号的FIRST和FOLLOW是否已求过*/
char empty[20]; /*记录可直接推出@的符号*/
char TEMP[50]; /*求FOLLOW时存放某一符号串的FIRST集合*/
int validity=1; /*表示输入文法是否有效*/
int ll=1; /*表示输入文法是否为LL(1)文法*/
int M[20][20]; /*分析表*/
char choose; /*用户输入时使用*/
char empt[20]; /*求_emp()时使用*/
char fo[20]; /*求FOLLOW集合时使用*/
/*******************************************
判断一个字符是否在指定字符串中
********************************************/
int in(char c,char *p)
{
int i;
if(strlen(p)==0)
return(0);
for(i=0;;i++)
{
if(p[i]==c)
return(1); /*若在,返回1*/
if(i==strlen(p))
return(0); /*若不在,返回0*/
}
}
/*******************************************
得到一个不是非终结符的符号
********************************************/
char c()
{
char c=A;
while(in(c,non_ter)==1)
c++;
return(c);
}
/*******************************************
分解含有左递归的产生式
********************************************/
void recur(char *point)
{ /*完整的产生式在point[]中*/
int j,m=0,n=3,k;
char temp[20],ch;
ch=c(); /*得到一个非终结符*/
k=strlen(non_ter);
non_ter[k]=ch;
non_ter[k+1]=\0;
for(j=0;j=strlen(point)-1;j++)
{
if(point[n]==point[0])
{ /*如果|后的首符号和左部相同*/
for(j=n+1;j=strlen(point)-1;j++)
{
while(point[j]!=|point[j]!=\0)
temp[m++]=point[j++];
left[count]=ch;
memcpy(right[count],temp,m);
right[count][m]=ch;
right[count][m+1]=\0;
您可能关注的文档
- 镀膜机常见故障及解决预防措施2试卷.doc
- 2016届如东中学高三阶段检测化学研讨.doc
- 2016届山东省潍坊市青州市高三上学期10月阶段性检测政治研讨.doc
- CorelDraw常用快捷键研讨.doc
- 工程概预算作业题整理版试卷.doc
- 2016届太原市高三上学期阶段性测评物理卷(一)(2015.11)研讨.doc
- CORELDRAW快捷键大全研讨.doc
- 焊工特种作业考证复习试卷.doc
- CorelDRAW快捷键全攻略研讨.doc
- 华锐风机常见故障试卷.doc
- D3-35kV中性点小电阻接地技术规范书20160930最终版研讨.doc
- 2016年10月最新版工业产品生产许可证实施细则65-燃气热水器研讨.doc
- D11车辆DF5S300系列变速箱使用说明书研讨.doc
- 2016年10月最新版工业产品生产许可证实施细则69-人民币鉴别仪研讨.doc
- D50S-000106ASM(启动运行说明书)研讨.doc
- 2016年10月最新版工业产品生产许可证实施细则70-危险化学品无机产品研讨.doc
- D310门板注塑模模具设计研讨.doc
- DA000004以太网技术原理研讨.doc
- day19-MyBatis入门研讨.doc
- 2016年10月最新版工业产品生产许可证实施细则71-危险化学品氯碱研讨.doc
文档评论(0)