亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 預測分析法實現(xiàn)的語法分析器.txt

?? 預測分析法實現(xiàn)的語法分析器 預測分析法實現(xiàn)的語法分析器
?? TXT
字號:
#include<stdio.h>

#include<malloc.h>

 

struct struCH{

       char              ch;

       struct            struCH *next;

}struCH,*temp,*head,*shift,*top,*base;

/*head指向線性鏈表的頭結點,shift指向動態(tài)建成的結點

 *top和base分別指向堆棧的頂和底

 */

FILE             *fp;

char              curchar;        /*存放當前待比較的字符*/

char              curtocmp;     /*存放當前棧頂的字符*/

char              ch;

int                 right, i,j;

int table[5][9]={                /*存儲預測分析表,1為有產生式,0為無*/

                     {1,0,0,0,0,1,0,0,0},

                     {0,1,1,0,0,0,1,1,1},

                     {1,0,0,0,0,1,0,0,0},

                     {0,1,1,1,1,0,1,1,1},

                     {1,0,0,0,0,1,0,0,0}}; 

 

void main(int argc,char *argv[]){

       void puch(char ch);

       void pop();

       void doforpush(int t);

       void identify();

       

       int errnum=0, k=0, countchar=0, rownum;

       int m=0;

       int charerr=0;  /*有非法字符時的開關控制量*/

       

       /*******************以只讀方式打開文件*********************/

              

       if((fp=fopen(argv[1],"r"))==NULL){

              printf("\n\tCan not open file %s,or not exist it!\n",argv[1]);

              exit(0);     /*文件不存在or打不開時,正常退出程序*/

       }

       else printf("\n\tSuccess open file: %s\n",argv[1]);       /*成功打開文件*/

              

       /******************遍歷整個文件檢測是否有非法字符********************/

       

       /*如果用while(!feof(fp))語言,將會多出一個字符而難以控制,

        *所以這里采用先計算字符數量再遍歷整個文件來檢測其否有非法字符*/

       /*[1]計算文件中字符數量*/

       while(!feof(fp)){

              ch=getc(fp);          /*這里只是讓指針往前移*/

              countchar++;        /*統(tǒng)計文件中的字符數(包括換行符及文件結束符)*/

       }

       rewind(fp);                   /*將fp文件指針重新指向文件頭處,以備后面對文件的操作*/

       if(countchar==0){        /*空文件*/

              printf("\t%s is a blank file!\n",argv[1]); 

              exit(0);                  /*正常退出本程序*/

       }     

       /*[2]開始遍歷文件*/

       while(k<(countchar-1)){/*加換行符后countchar仍多一個,故減1*/

              ch=getc(fp);           

              if(!(ch=='('||ch==')'||ch=='i'||ch=='+'||ch=='-'||ch=='*'||ch=='/'||ch=='#'||ch=='\n')){ 

                     charerr=1;errnum++;/*charerror出錯標記,errnum統(tǒng)計出錯個數*/

              }

              k++;       

       }

       rewind(fp);            /*將fp文件指針重新指向文件頭處,以備后面的建鏈表操作*/

       if(charerr==1){     /*文件中有非法字符*/

              printf("\n\t%d Unindentify characters in file %s \n",errnum,argv[1]);

              exit(0);           /*正常退出本程序*/

       }

              

       /*******************非空且無非法字符,則進行識別操作*****************/

       for(rownum=1;m<(countchar-1);rownum++){    /*識別所有行,rownum記錄行號*/

              /* 初始變量及堆棧和 */

              right=1;          

              /* '#''E'進棧 */

              base=malloc(sizeof(struCH));   /*初始化堆棧*/

              base->next=NULL;

              base->ch='#';

              temp=malloc(sizeof(struCH));

              temp->next=base;

              temp->ch='E';

              top=temp;                               /*棧頂指針top指向棧頂*/

              

              /*初始存放待識別的表達式的線性鏈表頭*/

              shift=malloc(sizeof(struCH));

              shift->next=NULL;

              head=shift;

              

              /*讀取一行形成線性鏈表*/

              ch=getc(fp);putchar(ch);m++;

              while(ch!='\n'&&m<(countchar)){ /*行末or到文件尾。最后會讀取文件結束符*/

                     /*讀取ch,讀取存入鏈*/

                     temp=malloc(sizeof(struCH));

                     temp->ch=ch;

                     temp->next=NULL;

                     shift->next=temp;

                     shift=shift->next;

                     ch=getc(fp);

                     if(m!=(countchar-1)) putchar(ch);  /*不輸出最后一次讀取的文件結束符*/

                     m++;

              }

 

              head=head->next;        /*消去第一個空頭結點,并使head指向非空線性鏈表頭*/

              shift=head;                   /*shift指向頭結點,以便后面識別操作*/

              putchar('\n');

              identify();                     /*開始識別一行*/

              if(!right)                       /*錯誤提示:[文件名] Line [行號]:error expression!*/

                     printf("%s  Line %d:\t  error expression!\n",argv[1],rownum);      

              else                              /*正確提示:[文件名] Line [行號]:right expression!*/

                     printf("%s  Line %d:\t  right expression!\n",argv[1],rownum);       

              putchar('\n');

       }/*end for*/    

       printf("Completed!\n");

       fclose(fp);      /*關閉文件*/

       exit(0);           /*正常退出程序*/

}

 

/*入棧函數*/

void push(char ch){

       temp=malloc(sizeof(struCH));

       temp->ch=ch;

       temp->next=top;

       top=temp;

}

 

/*出棧函數*/

void pop(void){

       curtocmp=top->ch;

       if(top->ch!='#')

              top=top->next;

}

 

/*根據數組下標計算的值找對應的產生式,并入棧*/

void doforpush(int t){

       switch(t){

              case 0:push('A');push('T');break;

              case 5:push('A');push('T');break;

              case 11:push('A');push('T');push('+');break;

              case 12:push('A');push('T');push('-');break;

              case 20:push('B');push('F');break;

              case 25:push('B');push('F');break;

              case 33:push('B');push('F');push('*');break;

              case 34:push('B');push('F');push('/');break;

              case 40:push('i');break;

              case 45:push(')');push('E');push('(');

       }

}

 

/*根據curchar,curtocmp轉為數字以判斷是否有產生式*/

void changchartoint()

{

       switch(curtocmp)          /*非終結符:棧頂*/

       {

              case 'A':i=1;break;

              case 'B':i=3;break;

              case 'E':i=0;break;

              case 'T':i=2;break;

              case 'F':i=4;

       }

       switch(curchar)             /*終結符:待識別的表達式中*/

       {

              case 'i':j=0;break;

              case '+':j=1;break;

              case '-':j=2;break;

              case '*':j=3;break;

              case '/':j=4;break;

              case '(':j=5;break;

              case ')':j=6;break;

              case '#':j=7;

       }

}

 

/*識別算法函數*/

void identify()

{

       int t;

       for(;;)

       {

              pop();                                  /*讀取棧頂的字符存curtocmp中*/

              curchar=shift->ch;                /*讀取鏈中的一個字符存curchar*/

              printf("\t%c-->%c\n",curchar,curtocmp);            

              if(curtocmp=='#' && curchar=='#')                     break;

              if(curtocmp=='A'||curtocmp=='B'||curtocmp=='E'||curtocmp=='T'||curtocmp=='F'){

                     if(curtocmp!='#'){         /*[1]未到棧底時,匹配字符*/

                            changchartoint();

                            if(table[i][j]){                /*[1.1]有產生式*/

                                   t=10*i+j;               /*計算產生式在數組中的位置*/

                                   doforpush(t);         /*找對應t的產生式,并入棧*/

                                   continue;

                            }

                            else{                             /*[1.2]沒有產生式*/

                                   right=0;                  /*出錯*/

                                   break;

                            }

                     }

                     else{                               /*[2]到棧底,當前比較字符為'#'*/

                            if(curtocmp!=curchar){ /*輸入行中最后一字符非'#'*/

                                   right=0;                 /*出錯*/

                                   break;

                            }

                            else

                                   break;                   /*正確*/

                     }

              }

              else{       /*若當前字符為終結符*/

                     if(curtocmp!=curchar){

                            right=0;                      /*出錯*/

                            break;

                     }

                     else{

                            shift=shift->next;        /*讀取下一個字符*/

                            continue;

                     }

              }

       }/*end for*/

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久九九久久九九| 久草在线在线精品观看| 丝袜国产日韩另类美女| 极品销魂美女一区二区三区| 99久久精品国产观看| 欧美中文字幕一二三区视频| 久久香蕉国产线看观看99| 亚洲男人都懂的| 国产一区二区剧情av在线| 欧美三级电影在线观看| 国产精品污www在线观看| 日韩精品成人一区二区在线| 99久久99久久精品免费观看| 欧美一卡在线观看| 亚洲午夜久久久| 成人av影院在线| wwww国产精品欧美| 日韩成人免费电影| 色婷婷一区二区三区四区| 国产精品久久久久久久蜜臀| 久久66热偷产精品| 日韩欧美成人一区| 日韩精品乱码免费| 欧美精品日韩精品| 洋洋成人永久网站入口| 成人午夜视频福利| 国产欧美日韩在线视频| 91碰在线视频| 国产亚洲精品精华液| 久99久精品视频免费观看| 欧美一级在线免费| 热久久久久久久| 日韩一区二区三区视频在线观看| 亚洲五码中文字幕| 欧美调教femdomvk| 香蕉加勒比综合久久| 欧美日产在线观看| 图片区小说区区亚洲影院| 欧美日韩综合色| 天堂va蜜桃一区二区三区 | 亚洲欧美日韩中文播放| 成人av免费在线观看| 国产精品卡一卡二| 91香蕉视频mp4| 亚洲美女偷拍久久| 欧美日韩在线直播| 青娱乐精品视频| 欧美mv和日韩mv的网站| 韩国视频一区二区| 国产日韩精品一区二区三区在线| 国产成+人+日韩+欧美+亚洲| 中文字幕不卡一区| 色婷婷av一区二区三区大白胸| 一区二区三区中文字幕在线观看| 91九色02白丝porn| 日韩在线观看一区二区| 日韩一级黄色片| 韩国女主播一区二区三区| 中文字幕精品一区| 欧美影院精品一区| 国产一区二区三区四| 国产精品国产a级| 欧美日韩国产成人在线免费| 日韩国产成人精品| 久久久精品蜜桃| 欧美视频你懂的| 久久爱www久久做| 中文字幕中文字幕一区| 欧美日韩三级在线| 国产一区二区三区黄视频 | 亚洲综合色丁香婷婷六月图片| 欧美三级在线视频| 国产精品99久| 亚洲第一电影网| 国产亚洲成aⅴ人片在线观看| 91色|porny| 精品一区二区久久久| 亚洲免费观看高清完整版在线观看熊 | 国产欧美日韩激情| 欧美色大人视频| 风间由美一区二区av101| 天天操天天干天天综合网| 久久久久免费观看| 88在线观看91蜜桃国自产| 成人免费福利片| 麻豆精品蜜桃视频网站| 一区二区三区四区精品在线视频| 精品久久久久久久久久久院品网 | 亚洲精品日韩专区silk| 日韩欧美国产一区在线观看| 色狠狠一区二区| 国产盗摄一区二区| 蜜臀av性久久久久av蜜臀妖精| 亚洲私人黄色宅男| 国产欧美综合在线观看第十页| 欧美日韩二区三区| 国产精品一区专区| 久久人人97超碰com| 欧美成人乱码一区二区三区| av一区二区三区| 国产中文一区二区三区| 日韩影院在线观看| 伊人色综合久久天天人手人婷| 国产午夜精品久久久久久免费视| 欧美喷水一区二区| 在线观看亚洲a| 日本国产一区二区| 成人a区在线观看| 粉嫩av亚洲一区二区图片| 国内精品在线播放| 精品综合久久久久久8888| 午夜精品久久一牛影视| 亚洲综合丝袜美腿| 亚洲女人小视频在线观看| 中文字幕一区在线| **欧美大码日韩| 亚洲欧美日韩中文播放| 亚洲乱码中文字幕综合| 亚洲色图视频网| 亚洲精品欧美专区| 亚洲香肠在线观看| 天天影视涩香欲综合网| 日本亚洲一区二区| 久久爱www久久做| 国产精品一二一区| zzijzzij亚洲日本少妇熟睡| 波多野结衣在线一区| 99在线精品视频| 色婷婷久久99综合精品jk白丝 | 久久久久久免费毛片精品| 亚洲精品一线二线三线无人区| 欧美电视剧在线看免费| 久久综合色一综合色88| 欧美国产精品一区二区| 国产精品国产三级国产aⅴ入口| 国产精品国产a| 亚洲午夜在线电影| 老司机免费视频一区二区三区| 国产在线精品一区在线观看麻豆| 国产真实乱偷精品视频免| 国产成人激情av| 色综合天天综合狠狠| 欧美女孩性生活视频| 精品日韩99亚洲| 国产精品的网站| 亚洲超碰精品一区二区| 久久精品国产一区二区| 成人高清免费观看| 欧美日韩久久久| 久久精品一区二区三区不卡| 亚洲精品国产成人久久av盗摄 | 成人综合婷婷国产精品久久蜜臀 | 国产美女娇喘av呻吟久久| 国产suv精品一区二区三区| 99久久伊人久久99| 91麻豆精品国产91久久久久| 久久久久国产精品麻豆ai换脸| 国产精品激情偷乱一区二区∴| 亚洲国产精品久久人人爱| 国产麻豆视频一区二区| 99久久国产综合精品麻豆| 日韩一区二区三区电影在线观看 | 91蝌蚪国产九色| 日韩女优制服丝袜电影| 亚洲色图在线视频| 国产制服丝袜一区| 欧美另类高清zo欧美| 国产精品你懂的| 美女网站在线免费欧美精品| 91久久奴性调教| 国产欧美一区二区精品久导航 | 亚洲午夜羞羞片| 成人av综合一区| 精品区一区二区| 亚洲成av人片在线观看无码| 成人免费高清在线观看| 欧美不卡视频一区| 亚洲va国产天堂va久久en| 99久久免费国产| 国产亚洲欧美激情| 久久精品国内一区二区三区| 欧美日韩国产电影| 亚洲综合免费观看高清完整版在线 | 欧美在线999| 国产精品视频一区二区三区不卡| 老司机精品视频导航| 51精品国自产在线| 亚洲综合一区二区| 色又黄又爽网站www久久| 国产欧美日韩在线| 粉嫩高潮美女一区二区三区| 久久综合久久综合久久| 蜜臀av一区二区| 91精品黄色片免费大全| 亚洲成人在线观看视频| 欧美性大战久久久久久久蜜臀| 自拍偷拍亚洲欧美日韩| 99re66热这里只有精品3直播| 国产丝袜在线精品| 粉嫩aⅴ一区二区三区四区|