編譯原理-語法分析程序設(shè)計(預(yù)測分析法)_第1頁
編譯原理-語法分析程序設(shè)計(預(yù)測分析法)_第2頁
編譯原理-語法分析程序設(shè)計(預(yù)測分析法)_第3頁
編譯原理-語法分析程序設(shè)計(預(yù)測分析法)_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、實驗?zāi)康臉?gòu)造文法的語法分析程序?qū)嶒炓?,實驗要求采用預(yù)測分析法對輸入的字符串進(jìn)展語法分析。實驗環(huán)境V實驗原理對文法G進(jìn)展語法分析,文法G如下所示:*0.Sa */*1. S *2.S(T) *3.TSW *4. W,SW *5.W;軟件設(shè)計與編程#include #include #include char str100; /存儲待分析的句子const char T = a(),#; /終結(jié)符,分析表的列符const char NT = STW; /非終結(jié)符,分析表的行符/*指向產(chǎn)生式右部符號串*/const char *p = /*0.Sa */a,/*1. S */ ,/*2.S(T) *

2、/(T),/*3.TSW */SW,/*4. W,SW */,SW,/*5.W; */; /設(shè)Mij=x,通過pMij=px獲取右部符號串。const int M6 = /* a ( ) , # */*S*/ 0, 1, 2, -1, -1, -1 , /*T*/ 3, 3, 3, -1, -1, -1 , /*W*/ -1, -1,-1, 5, 4, -1 ;void init()/輸入待分析的句子printf(請輸入待分析的句子(以$完畢):n);scanf(%s,str);int lin(char c);/非終結(jié)符轉(zhuǎn)換為行號int col(char c);/終結(jié)轉(zhuǎn)換為列號bool isN

3、T(char c);/isNT判斷是否是非終結(jié)符bool isT(char c);/isT判斷是否是終結(jié)符。void main(void)int i,j=0;int flag=1,flag2=0;char A;/設(shè)置指示句子的當(dāng)前字符char stack20=#,S; /棧賦初值int top = 1 ;/設(shè)置棧頂指針char X = ; /存儲棧頂字符init();A=str0; printf(t步數(shù)t分析棧t輸入串t所用規(guī)那么n);/在屏幕上輸出列表標(biāo)題while ( 1 )printf(nt(%d)t,+j);/輸出當(dāng)前執(zhí)行步數(shù)for ( i = 0 ; i = 0; i-)stack+

4、top = *(pMlin(X)col(A) + i ) ;elseprintf(Error in main()%cn,X);exit(0);int lin(char c)for(int i = 0; i %cn,c);exit(0) ;int col(char c)for (int i=0; i%cn,c);exit(0);bool isNT(char c) /是否是非終結(jié)符for (int i = 0; i (int)strlen(NT); i + )if (c=NTi)return true;return false;bool isT(char c) /是否是終結(jié)符不包括#for (int i = 0; i (int

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論