版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、編譯原理 課程實(shí)驗(yàn)報(bào)告班級(jí)學(xué)號(hào): 姓名: 實(shí)驗(yàn)名稱: 遞歸下降分析法 一、實(shí)驗(yàn)?zāi)康模?根據(jù)某一文法編制調(diào)試遞歸下降分析程序,以便對(duì)任意輸入的符號(hào)串進(jìn)行分析。本次實(shí)驗(yàn)的目的主要是加深對(duì)遞歸下降分析法的理解。二、實(shí)驗(yàn)要求:對(duì)下列文法,用遞歸下降分析法對(duì)任意輸入的符號(hào)串進(jìn)行分析: (1)E->TG(2)G->+TG|TG(3)G->(4)T->FS(5)S->*FS|/FS(6)S->(7)F->(E)(8)F->i輸出的格式如下:(1)遞歸下降分析程序,編制人:姓名,學(xué)號(hào),班級(jí)(2)輸入一以#結(jié)束的符號(hào)串(包括+*/()i#):在此位置輸入符號(hào)串例如
2、:i+i*i# (3)輸出結(jié)果:i+i*i#為合法符號(hào)串備注:輸入一符號(hào)串如i+i*#,要求輸出為“非法的符號(hào)串”。注意:1.表達(dá)式中允許使用運(yùn)算符(+-*/)、分割符(括號(hào))、字符i,結(jié)束符#; 2.如果遇到錯(cuò)誤的表達(dá)式,應(yīng)輸出錯(cuò)誤提示信息(該信息越詳細(xì)越好);三、實(shí)驗(yàn)過程:程序設(shè)計(jì):1.模塊設(shè)計(jì):將程序分成合理的多個(gè)模塊(函數(shù)),每個(gè)模塊做具體的同一事情。2.寫出(畫出)設(shè)計(jì)方案:模塊關(guān)系簡(jiǎn)圖、流程圖、全局變量、函數(shù)接口等。程序編寫:1.定義部分:定義常量、變量、數(shù)據(jù)結(jié)構(gòu)。2.初始化:從文件將輸入符號(hào)串輸入到字符緩沖區(qū)中。3.利用遞歸下降分析法,對(duì)每個(gè)非終結(jié)符編寫函數(shù),在主函數(shù)中調(diào)用文法開
3、始符號(hào)的函數(shù)。四、實(shí)驗(yàn)結(jié)果(1)程序流程圖開始輸入待處理的字符串得到字符串的長(zhǎng)度將開始符E放入堆棧得到第一個(gè)字符token遞歸下降分析輸出信息結(jié)束 開始輸出分析棧內(nèi)容和當(dāng)前動(dòng)作將分析棧的E換成EG是TGreturn 1return 0Y N 主函數(shù)main( )流程圖 E( )過程流程圖開始輸出分析棧內(nèi)容和當(dāng)前動(dòng)作將分析棧的T換成FS是FSreturn 1return 0Y N T( )過程流程圖將分析棧的G換成TG是TG開始token是+ token是- 輸出分析棧信息輸出分析棧信息輸出分析棧信息匹配+匹配- 返回return 1return 0Y Y N N Y N G( )過程流程圖開始
4、token是(token是i輸出錯(cuò)誤輸出分析棧信息將分析棧最后一個(gè)元素?fù)Q成E輸出分析棧信息匹配i匹配(進(jìn)行E過程匹配)N N Y Y F( )過程流程圖開始輸出分析棧信息token是*token是/將棧頂元素彈出匹配*匹配/將堆棧棧頂元素?fù)Q成FSF過程S過程結(jié)束 S( )過程流程圖(2)運(yùn)行結(jié)果示例程序:#include <stdio.h>#include<dos.h>#include<stdlib.h>#include<string.h>char a50 ,b50,d500,e10;char ch;int n1,i1=0,flag=1,n=5;
5、int E();int E1();int T();int G();int S();int F();void input();void input1();void output();void main() /*遞歸分析*/int f,p,j=0;char x; d0='E' d1='=' d2='>' d3='T' d4='G' d5='#'printf("遞歸下降分析程序,編制人:_,_,_n");printf("輸入一以#結(jié)束的符號(hào)串(包括+ - * / ( )
6、 i #,且長(zhǎng)度小于50):");doscanf("%c",&ch);aj=ch;j+;while(ch!='#');n1=j;ch=b0=a0;printf("文法t分析串ttt分析字符tt剩余串n");f=E1();if(f=0) return ;if (ch='#') printf("acceptn"); p=0;x=dp;while(ap!='#') printf("%c",ap+);printf("為合法字符!n");e
7、lse /printf("errorn");j=0;while(aj!='#') printf("%c",aj+);printf("非法字符!n");printf("回車返回n");getchar();getchar(); return; printf("n");printf("回車返回n");getchar();getchar();int E1() int f,t;printf("E->TGt"); flag=1;input();i
8、nput1();f=T();if (f=0) return(0);t=G();if (t=0) return(0);else return(1);int E() int f,t;printf("E->TGt"); e0='E'e1='='e2='>'e3='T'e4='G'e5='#'output();flag=1;input();input1();f=T();if (f=0) return(0);t=G();if (t=0) return(0);else retur
9、n(1);int T() int f,t;printf("T->FSt");e0='T'e1='='e2='>'e3='F'e4='S'e5='#' output();flag=1;input();input1();f=F();if (f=0)return(0);t=S(); if (t=0) return(0);else return(1);int G() int f;if(ch='+') bi1=ch;printf("G->+TGt
10、"); e0='G'e1='='e2='>'e3='+'e4='T'e5='G'e6='#'output(); flag=0;input();input1();ch=a+i1;f=T();if (f=0)return(0);f=G();if(f=0)return 0;else return 1;else if(ch='-') bi1=ch;printf("G->-TGt"); e0='G'e1='=
11、39;e2='>'e3='-'e4='T'e5='G'e6='#'output(); flag=0;input();input1();ch=a+i1;f=T();if (f=0)return(0);f=G();if(f=0)return 0;else return 1;elseprintf("G->t");e0='G'e1='='e2='>'e3=''e4='#'output();flag=1; i
12、nput();input1();return(1);int S()int f,t;if(ch='*') bi1=ch;printf("S->*FSt"); e0='S'e1='='e2='>'e3='*'e4='F'e5='S'e6='#'output();flag=0;input();input1();ch=a+i1;f=F();if (f=0)return(0);t=S();if (t=0)return(0);else return
13、(1);else if(ch='/') bi1=ch;printf("S->/FSt"); e0='S'e1='='e2='>'e3='/'e4='F'e5='S'e6='#'output();flag=0;input();input1();ch=a+i1;f=F();if (f=0)return(0);t=S();if (t=0)return(0);else return(1);elseprintf("S->t&quo
14、t;);e0='S'e1='='e2='>'e3=''e4='#'output();flag=1; ai1=ch;input();input1();return(1);int F() int f;int j;if(ch='(') bi1=ch;printf("F->(E)t");e0='F'e1='='e2='>'e3='('e4='E'e5=')'e6='#
15、'output();flag=0;input();input1();ch=a+i1;f=E();if (f=0) return(0);if(ch=')') bi1=ch;printf("F->(E)t"); flag=0;input();input1(); ch=a+i1;else printf("errorn"); j=0; while(aj!='#') printf("%c",aj+);printf("非法字符!n"); return(0); else if(ch=
16、'i') bi1=ch;printf("F->it");e0='F'e1='='e2='>'e3='i'e4='#'output();flag=0;input();input1();ch=a+i1; else printf("errorn");j=0;while(aj!='#') printf("%c",aj+);printf("非法字符!n");return(0);return(1);voi
17、d input() int j=0; for (;j<=i1-flag;j+) printf("%c",bj); /*輸出分析串*/ printf("ttt"); printf("%cttt",ch); /*輸出分析字符*/ void input1() int j; for (j=i1+1-flag;j<n1;j+) printf("%c",aj); /*輸出剩余字符*/ printf("n");void output() /*推導(dǎo)式計(jì)算*/int m,k,j,q; int i=0;m=0;k=0;q=0; i=n;dn='='dn+1='>'dn+2='#'n=n+2;i=n;
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 基于大數(shù)據(jù)的2025年度冷藏車調(diào)度管理系統(tǒng)合同2篇
- 長(zhǎng)沙衛(wèi)生職業(yè)學(xué)院《中國(guó)古典文獻(xiàn)學(xué)》2023-2024學(xué)年第一學(xué)期期末試卷
- 2025版智能建筑抹灰分項(xiàng)工程勞務(wù)服務(wù)協(xié)議書4篇
- 科技助力川菜館實(shí)現(xiàn)可持續(xù)發(fā)展
- 從用戶需求出發(fā)的未來酒店餐飲空間設(shè)計(jì)策略
- 小學(xué)科學(xué)課程中實(shí)踐活動(dòng)的開展與問題解決
- 2025版門樓金屬卷簾門安裝與維護(hù)服務(wù)合同4篇
- 2025年度高端別墅定制設(shè)計(jì)與建造合同協(xié)議2篇
- 2024鋁質(zhì)板材市場(chǎng)銷售合作協(xié)議2篇
- 父母心理韌性培養(yǎng)家庭教育的關(guān)鍵要素
- 普通高中生物新課程標(biāo)準(zhǔn)
- 茉莉花-附指法鋼琴譜五線譜
- 結(jié)婚函調(diào)報(bào)告表
- SYT 6968-2021 油氣輸送管道工程水平定向鉆穿越設(shè)計(jì)規(guī)范-PDF解密
- 冷庫(kù)制冷負(fù)荷計(jì)算表
- 肩袖損傷護(hù)理查房
- 設(shè)備運(yùn)維管理安全規(guī)范標(biāo)準(zhǔn)
- 辦文辦會(huì)辦事實(shí)務(wù)課件
- 大學(xué)宿舍人際關(guān)系
- 2023光明小升初(語(yǔ)文)試卷
- GB/T 14600-2009電子工業(yè)用氣體氧化亞氮
評(píng)論
0/150
提交評(píng)論