下載本文檔
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上實(shí)驗(yàn)1 詞法分析程序設(shè)計(jì)【實(shí)驗(yàn)?zāi)康摹浚?)理解詞法分析在編譯程序中的作用(2)加深對(duì)有窮自動(dòng)機(jī)模型的理解(3)掌握詞法分析程序的實(shí)現(xiàn)方法和技術(shù)【實(shí)驗(yàn)內(nèi)容】對(duì)一個(gè)簡(jiǎn)單語(yǔ)言的子集編制一個(gè)一遍掃描的詞法分析程序?!驹O(shè)計(jì)思路】1、流程圖置初值調(diào)用掃描子程序輸出串結(jié)束?輸出單詞二元組是否結(jié)束圖1.1 詞法分析主程序示意圖2、源程序代碼(1)scan.h /頭文件-掃描程序#include<stdio.h>#include<string.h>#define CLEAR memset(token,'0',sizeof(token)/清空數(shù)組t
2、okenchar prog80,token8;char ch;int syn,p,m,n,sum; /p是緩沖區(qū)prog的指針,m是token的指針char *rwtab6="begin","if","then","while","do","end"void scanner() /詞法掃描程序CLEAR;m=0;while(ch=' ')+p;ch=progp; /讀下一個(gè)字符;if(ch>='a'&&ch<=
3、9;z')|(ch>='A'&&ch<='Z')m=0;while(ch>='a'&&ch<='z')|(ch>='A'&&ch<='Z')|(ch>='0'&&ch<='9')tokenm+=ch;+p;ch=progp;/讀下一個(gè)字符;tokenm+='0'syn=10;for(n=0;n<6;+n)if(strcmp(to
4、ken,rwtabn)=0)syn=n+1;break;elseif(ch>='0'&&ch<='9')sum=0;while(ch>='0'&&ch<='9')sum=sum*10+ch-'0'/將ch轉(zhuǎn)換為數(shù)字+p;ch=progp;syn=11;elseswitch(ch)/其他字符情況case'<':m=0;tokenm+=ch;+p;ch=progp;if(ch='>')syn=21;+m;tokenm=c
5、h;else if(ch='=')syn=22;+m;tokenm=ch;elsesyn=20;break;case'>':token0=ch;+p;ch=progp;if(ch='=')syn=24;token0=ch;elsesyn=23;break;case':':token0=ch;+p;ch=progp;if(ch='=')syn=18;+m;tokenm=ch;+p;ch=progp;elsesyn=17;break;case'+':syn=13;token0=ch;ch=prog
6、+p;break;case'-':syn=14;token0=ch;ch=prog+p;break;case'*':syn=15;token0=ch;ch=prog+p;break;case'/':syn=16;token0=ch;ch=prog+p;break;case'=':syn=25;token0=ch;ch=prog+p;break;case'':syn=26;token0=ch;ch=prog+p;break;case'(':syn=27;token0=ch;ch=prog+p;brea
7、k;case')':syn=28;token0=ch;ch=prog+p;break;case'#':syn=0; token0=ch;ch=prog+p;break;default:syn=-1;(2)word.cpp / 詞法分析主程序#include"scan.h"void main(void)p=0;printf("n please input string:n");doch=getchar();progp+=ch;while(ch!='#');p=0;ch=prog0;if(ch>='
8、;0'&&ch<='9')printf("error!n");elsedoscanner();/調(diào)用掃描子程序switch(syn)case 11:printf("(%d,%d)n",11,sum);break;case -1:printf("error!n");break;default:printf("(%d,'%s')n",syn,token); while(syn!=0);【思考題】在編程過(guò)程中遇到了哪些問(wèn)題,你是如何解決的。答:?jiǎn)栴}1:在“讀下一個(gè)字符“的時(shí)候遇到少讀或多讀一個(gè)字符的情況。(解決:通過(guò)多次調(diào)試將讀字符的每種情況都考慮)問(wèn)題2:當(dāng)輸入數(shù)字開(kāi)頭的字符串時(shí),需
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年陜西能源職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)適應(yīng)性測(cè)試題庫(kù)及參考答案詳解
- 2026年福建省龍巖單招職業(yè)適應(yīng)性測(cè)試題庫(kù)及答案詳解1套
- 2026年重慶機(jī)電職業(yè)技術(shù)大學(xué)單招職業(yè)適應(yīng)性考試題庫(kù)附答案詳解
- 2026年中山職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)傾向性測(cè)試題庫(kù)參考答案詳解
- 2026年黑龍江建筑職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)適應(yīng)性考試題庫(kù)及答案詳解一套
- 2026年山東城市建設(shè)職業(yè)學(xué)院?jiǎn)握新殬I(yè)技能考試題庫(kù)及參考答案詳解一套
- 2026年宿州職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)傾向性考試題庫(kù)帶答案詳解
- 2026年常州工業(yè)職業(yè)技術(shù)學(xué)院?jiǎn)握芯C合素質(zhì)考試題庫(kù)及完整答案詳解1套
- 2026年天津交通職業(yè)學(xué)院?jiǎn)握芯C合素質(zhì)考試題庫(kù)及參考答案詳解1套
- 2026年廣東舞蹈戲劇職業(yè)學(xué)院?jiǎn)握新殬I(yè)適應(yīng)性測(cè)試題庫(kù)及答案詳解一套
- 光伏電站巡檢與維護(hù)
- 小學(xué)校本課程-1藍(lán)色國(guó)土教學(xué)設(shè)計(jì)學(xué)情分析教材分析課后反思
- 廣州市荔灣區(qū)事業(yè)單位招聘事業(yè)編制人員考試真題2022
- GB/T 19867.4-2008激光焊接工藝規(guī)程
- 上下班交通安全知識(shí)考試試卷
- 航天航空企業(yè)介紹工作匯報(bào)總結(jié)計(jì)劃PPT模板
- 食堂消毒表格
- 模具定期保養(yǎng)點(diǎn)檢表
- 電工基礎(chǔ)(第六版)課后習(xí)題答案
- 快消品年度工作計(jì)劃
- 醫(yī)院后勤設(shè)備安全運(yùn)維管理
評(píng)論
0/150
提交評(píng)論