编译原理词法分析器代码(2)

2021-02-21 19:40

本人编的,结果也出来了

, buf[i++]='I', 调用后token="BEGI"。
void concat(char token[],char c)
{
for(int i=0;token[i];i++);
token[i]=c;
token[++i]='\0';
}
char reserve(char token[])
{
const char *table[]={"begin","end","integer","real","if","else"};
const char code[]={"{}acbd"};//if的单词种别为b,else的单词种别为d
for(int i=0;i<(int)strlen(code);i++)
if(strcmp(token,table[i])==0) return code[i];
return 'i';//标识符的单词种别为'i'
}
//预处理函数
void pro_process(char *buf)
{
ifstream cinf("B1_42.txt",ios::in);
int i=0;char old_c='\0',cur_c;//计数器,前一个字符,当前字符。
bool in_comment=false;//状态标志,false表示当前字符未处于注释中。
while(cinf.read(&cur_c,sizeof(char))){//从文件读一个字符
switch(in_comment){
case false:
if(old_c=='/' && cur_c=='*'){//进入注释
i--;//去除已存入扫描缓冲区的字符'/'
in_comment=true;
}
else {
if(old_c=='\\' && cur_c=='\n') //去除续行符'\',包括后续换行符。
i--;//去除已存入扫描缓冲区的字符'\'
else {
if(cur_c>='A' && cur_c<='Z') cur_c+=32;//大写变小写
if(cur_c=='\t' || cur_c=='\n') cur_c=' ';//空格
buf[i++]=cur_c ;
}
}
break;
case t
rue:
if(old_c=='*' && cur_c=='/')//离开注释
in_comment=false;
}//end of switch
old_c= cur_c;//保留前一个字符
}//end of while
buf[i]='#';
}


编译原理词法分析器代码(2).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:资阳市2011年中考政治试题

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: