根据文法:
E→E+T|E-T|T
T→T*F| T/F|F
F→(E)|i
1 #include<stdio.h> 2 #include<string.h> 3 #include<stdlib.h> 4 char TOken[10];//分开进行比较 5 char ch; 6 char r1[]={"begin"}; 7 char r2[]={"if"}; 8 char r3[]={"then"}; 9 char r4[]={"while"}; 10 char r5[]={"do"}; 11 char r6[]={"end"}; 12 char r7[]={"break"}; 13 char r8[]={"case"}; 14 char r9[]={"main"}; 15 char r10[]={"l(l|d)*"}; 16 char r11[]={"dd*"}; 17 char r12[]={"="}; 18 char r13[]={"+"}; 19 char r14[]={"-"}; 20 char r15[]={"*"}; 21 char r16[]={"/"}; 22 char r17[]={":"}; 23 char r18[]={"{"}; 24 char r19[]={"}"}; 25 char r20[]={"<"}; 26 char r21[]={"!="}; 27 char r22[]={"<="}; 28 char r23[]={">"}; 29 char r24[]={">="}; 30 char r25[]={"=="}; 31 char r26[]={"("}; 32 char r27[]={")"}; 33 char r28[]={"="}; 34 char r29[]={"--"}; 35 char r30[]={"++"}; 36 char r31[]={"!"}; 37 char r32[]={":="}; 38 char r33[]={";"}; 39 char r34[]={"."}; 40 char A[10000];//输入的所有值 41 int syn,row; 42 int n,m,p,sum,j; 43 static int i = 0; 44 void scaner(); 45 void E (); 46 void E1(); 47 void T (); 48 void T1(); 49 void F (); 50 int main() 51 { 52 row = 0 ; 53 p = 0 ; 54 printf("符号与种别码对照表如下: "); 55 printf(" 单词符号 种别码 单词符号 种别码 "); 56 printf(" begin 1 : 17 "); 57 printf(" if 2 { 18 "); 58 printf(" then 3 } 19 "); 59 printf(" while 4 < 20 "); 60 printf(" do 5 != 21 "); 61 printf(" end 6 <= 22 "); 62 printf(" break 7 > 23 "); 63 printf(" case 8 >= 24 "); 64 printf(" main 9 == 25 "); 65 printf(" l(l|d)* 10 ( 26 "); 66 printf(" dd* 11 ) 27 "); 67 printf(" = 12 = 28 "); 68 printf(" + 13 -- 29 "); 69 printf(" - 14 ++ 30 "); 70 printf(" * 15 ! 31 "); 71 printf(" / 16 := 32 "); 72 printf(" @ 0 ; 33 "); 73 printf(" 请输入您想转换的语句(输入@结束): "); 74 do{ 75 scanf("%c",&ch); 76 A[p]=ch; 77 p++; 78 }while(ch!='@');/*将输入的语句分别存入数组A[]中,@出现时结束语句*/ 79 p=0; 80 do 81 { 82 scaner();//进入函数进行判定 83 switch(syn) 84 { 85 case 11: printf("(%d,%d) ",syn,sum); break;//如果是11,那么就是数字 86 case -2: row=row++;break; 87 default: printf("(%d,%s) ",syn,TOken);break;//否则,就是变量名、关键词 88 } 89 }while (syn!=0); 90 system("pause"); 91 p=0; 92 scaner(); 93 E(); 94 if (syn==0) 95 printf(" 语法正确. "); 96 else 97 printf(" 语法错误. "); 98 99 } 100 void scaner()/*分别对标示符、数字、符号进行分析*/ 101 { 102 for(n=0;n<10;n++) 103 TOken[n]=0;/*每次循环完就清零*/ 104 m=0; 105 sum=0; 106 ch=A[i]; 107 while(ch==' '||ch==' ')/*如果字符是空格或者回车,跳过*/ 108 { 109 i++; 110 ch=A[i]; 111 } 112 if((ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z')) /*如果是标示符或者变量名,循环寻找*/ 113 { 114 m=0; 115 while((ch>='0'&&ch<='9')||(ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z'))/*找到一个变量名或者关键字,直到遇到空格为止*/ 116 { 117 TOken[m]=ch;m++; 118 i++;ch=A[i]; 119 } 120 TOken[m]='