⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 20052944.cpp

📁 编译原理实验、编译原理课程设计 vc++实现
💻 CPP
字号:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <malloc.h>
#include <conio.h>
#define NULL 0
FILE *fp;
char ch;
char *keyword[33]={"auto","break","case","char","const","continue","default","do","double", 
     "else","enum","extern","float","for","goto","if","int","long","register", 
     "return","short","signed","sizeof","static","struct","switch","typedef", 
     "union","unsigned","void","volatile","while","main"};
char *operatornum[6]={"+","-","*","/","++","--"};
char *comparison[7]={"<","<=","=",">",">=","<>","=="};
char *interpunction[8]={",",";",":=",".","(",")","{","}"};
//////////////////////////////////////////////////////////////////////////////////////////
bool search(char searchstr[],int wordtype)
{
 int i;
 switch (wordtype)
 {
   case 1:for(i=0;i<=32;i++)
    {
      if(strcmp(keyword[i],searchstr)==0)
       return(true);
    }
   case 2:for(i=0;i<=5;i++)
	{
   if(strcmp(operatornum[i],searchstr)==0)
    return(true);
	}
    break;
   case 3:for(i=0;i<=6;i++)
	{
    if(strcmp(comparison[i],searchstr)==0)
     return(true);
	}
	break;
   case 4:for(i=0;i<=7;i++)
	{
    if(strcmp(interpunction[i],searchstr)==0)
     return(true);
	}
  

}
return(false);
}

///////////////////////////////////////////////////////////////////////////////////////////
char letterprocess (char ch)//字母处理函数
{
int i=-1;
char letter[20];
while (isalnum(ch)!=0)
{
  letter[++i]=ch;
  ch=fgetc(fp);
};
letter[i+1]='\0';
if (search(letter,1))
{
  printf("(1,'%s')\n",letter);
  //strcat(letter,"\n");
  //fputs('<' letter '>\n',outp);
}
else
{
  printf("(2,'%s')\n",letter);
  //strcat(letter,"\n");
  //fputs(letter,outp);
}
return(ch);
}
///////////////////////////////////////////////////////////////////////////////////////////
char numberprocess(char ch)//数字处理程序
{
int i=-1;
char num[20];
while (isdigit(ch)!=0)
{
  num[++i]=ch;
  ch=fgetc(fp);
}
if(isalpha(ch)!=0)
{
  while(isspace(ch)==0)
  {
   num[++i]=ch;
            ch=fgetc(fp);
  }
  num[i+1]='\0';
  printf("出错!!!非法标识符:%s\n",num);
  goto u;
}
num[i+1]='\0';
    printf("(3,'%s')\n",num);
    //strcat(num,"\n");
    //fputs(num,outp);
u: return(ch);
}
//////////////////////////////////////////////////////////////////////////////////////////////
char otherprocess(char ch)
{
int i=-1;
char other[20];
if (isspace(ch)!=0)
{
  ch=fgetc(fp);
  goto u;
}
while ((isspace(ch)==0)&&(isalnum(ch)==0))
{
  other[++i]=ch;
  ch=fgetc(fp);
}
other[i+1]='\0';
if (search(other,2))
  printf("(4,'%s')\n",other);
else 
if (search(other,3))
   printf("(4,'%s')\n",other);
else
if (search(other,4))
    printf("(5,'%s')\n",other);
else 
   printf("出错!!!非法字符:%s\n",other);
u: return (ch);
}

/////////////////////////////////////////////////////////////////////////////////////////////
void main ()
{
char str,c;
printf("**********************************词法分析器************************************\n");
//outp=fopen("二元式表.txt","w");
if ((fp=fopen("come.txt","r"))==NULL)
  printf("源程序无法打开!!!\n");
else
{
  str =fgetc(fp);
  while (str!=EOF)
  {
   if (isalpha(str)!=0)
    str=letterprocess(str);
   else
   {
    if (isdigit(str)!=0)
     str=numberprocess(str);
    else
     str=otherprocess(str);
   }
    
  }
  printf("词法分析结束\n");
  printf("点击任意键退出!\n");
}
   c=getch();
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -