實驗1詞法分析.doc_第1頁
實驗1詞法分析.doc_第2頁
實驗1詞法分析.doc_第3頁
實驗1詞法分析.doc_第4頁
實驗1詞法分析.doc_第5頁
全文預覽已結(jié)束

下載本文檔

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

文檔簡介

實驗1 詞法分析 一、實驗目的 通過設計調(diào)試詞法分析程序,實現(xiàn)從源程序中分出各種單詞的方法;加深對課堂教學的理解;提高詞法分析方法的實踐能力。 二、實驗要求 (1)掌握詞法分析的實現(xiàn)方法。 (2)上機調(diào)試編出的詞法分析程序。 (3)源程序可以從鍵盤輸入也可以事先存在文件中 (4)將源程序中的各個單詞讀出后可以顯示在屏幕中也可以存在文件中(包括單詞的類別)三、實驗題目 用 C/C+ 語言編寫以下 C/C+ 子集的詞法分析程序。四、實驗代碼/*測試數(shù)據(jù)BEGINVAR A+,2A,A3,A4:INTEGER;A1:=1,A2:=123,A3:=123-12;WHILE A2=A3 DO A4:=234A*123/45+A1iF A1A2 THEN A1:=A4;ELSE A4:=(A1+A2)*A!;END*/#include#include#includeusing namespace std;int letter(char c)/字母if(c=A & c=0 & c=9)return 1;else return 0;int oper(char c)/運算符if(c=+ | c=- | c=* | c=/)return 1;else return 0;int relation(char c)/關系運算符if(c=|c=)return 1;else return 0;int jiefu(char c)/界符if(c=, | c=: | c=;| c=.| c=(| c=)return 1;else return 0;int border(char c)/單詞邊界if(c=, | c=: | c=;| c= | c=. | c=(| c=)| c=+ | c=- | c=* | c=/ | c=| c= )return 1;else return 0;int illegal(char *s)/找非法字符int i,l=strlen(s);for(i=0;il;i+)if(!letter(si) & !digit(si)return 1;return 0;int identifier(char *s)/標識符if(illegal(s)return 0;if( letter(s0) ) return 1;else return 0;int unsigned_word(char *s)/無符號數(shù)int i,len=strlen(s);for(i=0;ilen;i+)if(!digit(si)return 0;return 1;int r_word(char *s)/保留字if(illegal(s)return 0;else if(!strcmp(s,INTEGER) return 1;else if(!strcmp(s,WHILE) return 1; else if(!strcmp(s,BEGIN) return 1;else if(!strcmp(s,ELSE) return 1;else if(!strcmp(s,VAR) return 1;else if(!strcmp(s,END) return 1;else if(!strcmp(s,IF) return 1;else if(!strcmp(s,DO) return 1;else if(!strcmp(s,THEN) return 1;else return 0;void judge_word(char *s)/判斷單詞int len=strlen(s);if(len=0)return ;if(r_word(s)cout保留字: sendl;else if(identifier(s)cout標識符: sendl;else if(unsigned_word(s)cout無符號數(shù): sendl;else cout非法單詞: sendl;void main()char s100,word100;while(gets(s)int i,j=0,len=strlen(s);for(i=0;ilen;i+)if(border(si)wordj=0;j=0;judge_word(word);if(si=: & si+1=)cout賦值符:sisi+1 & si+1= | si= & si+1= | si=)cout關系運算符: sisi+1endl;i+;word0=0;continue;else if(relation(si)cout關系運算符: siendl;word0=0;continue;else if(oper(si)cout運算符: siendl;word0=0;contin

溫馨提示

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

最新文檔

評論

0/150

提交評論