日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

递归下降分析法

發布時間:2025/3/15 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 递归下降分析法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

根據文法:

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("符號與種別碼對照表如下:\n"); 55 printf(" 單詞符號 種別碼 單詞符號 種別碼\n"); 56 printf(" begin 1 : 17\n"); 57 printf(" if 2 { 18\n"); 58 printf(" then 3 } 19\n"); 59 printf(" while 4 < 20\n"); 60 printf(" do 5 != 21\n"); 61 printf(" end 6 <= 22\n"); 62 printf(" break 7 > 23\n"); 63 printf(" case 8 >= 24\n"); 64 printf(" main 9 == 25\n"); 65 printf(" l(l|d)* 10 ( 26\n"); 66 printf(" dd* 11 ) 27\n"); 67 printf(" = 12 = 28\n"); 68 printf(" + 13 -- 29\n"); 69 printf(" - 14 ++ 30\n"); 70 printf(" * 15 ! 31\n"); 71 printf(" / 16 := 32\n"); 72 printf(" @ 0 ; 33\n\n"); 73 printf(" 請輸入您想轉換的語句(輸入@結束):\n"); 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)\n",syn,sum); break;//如果是11,那么就是數字 86 case -2: row=row++;break; 87 default: printf("(%d,%s)\n",syn,TOken);break;//否則,就是變量名、關鍵詞 88 } 89 }while (syn!=0); 90 system("pause"); 91 p=0; 92 scaner(); 93 E(); 94 if (syn==0) 95 printf("\n 語法正確. \n"); 96 else 97 printf("\n 語法錯誤. \n"); 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=='\n')/*如果字符是空格或者回車,跳過*/ 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]='\0';/*將識別出來的字符和已定義的標示符作比較,輸出其種別碼*/ 121 if(strcmp(TOken,r1)==0){syn=1;} 122 else if(strcmp(TOken,r2)==0){syn=2;} 123 else if(strcmp(TOken,r3)==0){syn=3;} 124 else if(strcmp(TOken,r4)==0){syn=4;} 125 else if(strcmp(TOken,r5)==0){syn=5;} 126 else if(strcmp(TOken,r6)==0){syn=6;} 127 else if(strcmp(TOken,r7)==0){syn=7;} 128 else if(strcmp(TOken,r8)==0){syn=8;} 129 else if(strcmp(TOken,r9)==0){syn=9;} 130 131 else{syn=10;} 132 } 133 else if((ch>='0'&&ch<='9')) //數字 134 { 135 sum=0; 136 while((ch>='0'&&ch<='9')) 137 { 138 sum=sum*10+ch-'0';//顯示其對應數字sum 139 i++; 140 ch=A[i]; 141 } 142 syn=11; 143 } 144 else switch(ch) //有兩個的字符 145 { 146 case'<':m=0;TOken[m]=ch;m++; 147 i++;ch=A[i]; 148 if(ch=='=') 149 { 150 syn=22;//<= 151 TOken[m]=ch;m++;i++; 152 } 153 else{syn=20;}break;//< 154 155 case'>':m=0;TOken[m]=ch;m++; 156 i++;ch=A[i]; 157 if(ch=='='){ 158 syn=24;//>= 159 TOken[m]=ch;m++;i++; 160 } 161 else{syn=23;}break;//> 162 163 case':':m=0;TOken[m]=ch;m++; 164 i++;ch=A[i]; 165 if(ch=='=') 166 { 167 syn=32;//:= 168 TOken[m]=ch;m++;i++; 169 } 170 else 171 {syn=17;}break;//: 172 173 case'@':syn=0;TOken[0]=ch;break; 174 case'=':syn=12;TOken[0]=ch;break; 175 case'+':syn=13;TOken[0]=ch;break; 176 case'-':syn=14;TOken[0]=ch;break; 177 case'*':syn=15;TOken[0]=ch;break; 178 case'/':syn=16;TOken[0]=ch;break; 179 case'{':syn=18;TOken[0]=ch;break; 180 case'}':syn=19;TOken[0]=ch;break; 181 case'(':syn=26;TOken[0]=ch;break; 182 case')':syn=27;TOken[0]=ch;break; 183 case';':syn=33;TOken[0]=ch;break; 184 case'.':syn=34;TOken[0]=ch;break; 185 // case'\n':syn=-2;break; 186 default: syn=-1;TOken[0]=ch; 187 } 188 } 189 /*以下函數分別對應于子模塊程序*/ 190 191 void E(){ 192 printf("E "); 193 T(); 194 E1(); 195 } 196 197 void E1(){ 198 printf("E1 "); 199 if(syn==13||syn==14){ 200 scaner(); 201 T(); 202 E1(); 203 } 204 else { 205 if (syn!=27 && syn!=0) 206 printf("\n (%d,%s)語法錯誤! \n",syn, TOken); 207 } 208 } 209 210 void T(){ 211 printf("T "); 212 F(); 213 T1(); 214 } 215 216 void T1(){ 217 printf("T1 "); 218 if(syn==15||syn==16){ 219 scaner(); 220 F(); 221 T1(); 222 } 223 else{ 224 if(syn!=0&&syn!=28&&syn!=13&&syn!=14) 225 printf("\n (%d,%s)語法錯誤! \n",syn, TOken); 226 } 227 } 228 229 void F(){ 230 printf("F "); 231 if(syn==10||syn==11) 232 { 233 scaner(); 234 } 235 else if(syn==26) 236 { 237 scaner(); 238 E(); 239 if(syn==27){ 240 scaner(); 241 } 242 else 243 printf("\n (%d,%s)語法錯誤! \n",syn, TOken); 244 } 245 246 }

?

轉載于:https://www.cnblogs.com/oechen/p/6209734.html

總結

以上是生活随笔為你收集整理的递归下降分析法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美成人一区二区视频 | 日韩成人午夜影院 | 欧美精品偷拍 | 国产a精品| 中文字幕专区 | 五月婷婷色丁香 | 日韩免费中文字幕 | 精品国产成人亚洲午夜福利 | 天天婷婷 | 91成人在线观看喷潮蘑菇 | 国产丰满大乳奶水在线视频 | 啪啪导航| 日韩91| 女人性做爰24姿势视频 | 国产精品夜夜爽张柏芝 | 久久久久区 | 在线观看免费毛片 | 九九在线免费视频 | 日本激情网 | 四十路av | 激情婷婷 | 99热网址| 看av免费毛片手机播放 | 人妖黄色片| 在线免费观看一区 | 国产精品视频在线播放 | 99自拍偷拍| 国产成人无码久久久精品天美传媒 | 夜夜草av | 国产网站在线看 | 亚洲免费高清视频 | 两女双腿交缠激烈磨豆腐 | 亚洲第一第二区 | 国产福利小视频 | 禁漫天堂黄漫画无遮挡观看 | 日韩人妻无码精品久久免费 | 黄色一级片av| 日韩成人av在线 | 日本寂寞少妇 | 六月丁香色婷婷 | 人人爽在线 | 日本不卡影院 | 久久丫精品忘忧草西安产品 | 国产又粗又猛又爽免费视频 | 美国免费高清电影在线观看 | 91禁在线观看 | 欧日韩精品 | 天堂中文字幕免费一区 | 91精品啪| 污视频网站入口 | 国产精品啪 | 蜜桃视频在线播放 | 毛片亚洲av无码精品国产午夜 | 中文字幕免费高清在线 | 婷婷伊人综合 | 有奶水的迷人少妇 | 99久久久无码国产精品性青椒 | 日本视频免费在线 | 97人人插| 成人性生交大片免费看中文 | 一区二区日韩精品 | 九色丨蝌蚪丨成人 | 中文字幕超清在线免费观看 | 91涩漫成人官网入口 | 国产在线免费观看 | 国产一级生活片 | 久久影音| 日韩 在线| 打屁股无遮挡网站 | 日本黄色片一级 | 亚洲精品乱码久久久久久蜜桃麻豆 | 欧美亚洲精品在线观看 | 姐姐你真棒插曲快来救救我电影 | 精品久久久亚洲 | 中文字幕日韩人妻在线视频 | 成人午夜激情网 | 国产地址 | 黄色片女人 | 欧美精品系列 | 久久久久久亚洲精品 | 亚洲男人第一天堂 | 日韩精品一二三四区 | 国产真人做爰视频免费 | jizzjizz欧美69巨大 | 伊人网在线视频观看 | 朝桐光av一区二区三区 | 91免费小视频 | 91久久综合亚洲鲁鲁五月天 | 中文字幕 亚洲一区 | 国产精品久久久久毛片 | 日av一区 | 日本熟伦人妇xxxx | 久久人人爽人人爽人人 | 国产在线黄色 | 国产精品久久久久久妇女6080 | 日韩一区二区三免费高清在线观看 | 高h教授1v1h喂奶 | c逼| 日本少妇b|