括號(hào)匹配實(shí)驗(yàn)報(bào)告_第1頁(yè)
括號(hào)匹配實(shí)驗(yàn)報(bào)告_第2頁(yè)
括號(hào)匹配實(shí)驗(yàn)報(bào)告_第3頁(yè)
括號(hào)匹配實(shí)驗(yàn)報(bào)告_第4頁(yè)
括號(hào)匹配實(shí)驗(yàn)報(bào)告_第5頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡(jiǎn)介

1、 五、實(shí)驗(yàn)結(jié)果總結(jié)回答以下問題:你的測(cè)試充分嗎?為什么?你是怎樣考慮的?答:我認(rèn)為我的測(cè)試充分,因?yàn)槲业谋磉_(dá)式是隨機(jī)給出的,這樣選擇的數(shù)據(jù)具有隨機(jī)性,具有很強(qiáng)的代表性,并且每次的結(jié)果正確,因此我認(rèn)為我的測(cè)試比較充分。為什么你要選用?;蜿?duì)列或字符串或數(shù)組等抽象數(shù)據(jù)類型作為你應(yīng)用的數(shù)據(jù)結(jié)構(gòu)?答:我使用了棧這種抽象數(shù)據(jù)類型作為我應(yīng)用的數(shù)據(jù)結(jié)構(gòu),棧是一個(gè)只能訪問表的尾端數(shù)據(jù)的數(shù)據(jù)集合,是一種在表的一端進(jìn)行插入和刪除操作的線性表,數(shù)據(jù)具有“先進(jìn)后出”的特點(diǎn),而這種特點(diǎn)和括號(hào)匹配中檢驗(yàn)括號(hào)的“期限待的極限程度”這個(gè)特點(diǎn)相符合,因此選用棧這種數(shù)據(jù)結(jié)構(gòu)可以簡(jiǎn)化程序,更好的理解和實(shí)現(xiàn)程序,提高了程序運(yùn)行的時(shí)間效

2、率。用一段簡(jiǎn)短的代碼及說明論述你的應(yīng)用中主要的函數(shù)的主要處理部分。答:下面的代碼部分為Match函數(shù)中的主要處理部分,使用了兩個(gè)循環(huán)來處理輸入的表達(dá)式,第一個(gè)循環(huán)是用來從左到右掃描表達(dá)式遇到“(”或者“”就將括號(hào)入棧,第二個(gè)循環(huán)是用來掃描表達(dá)式,如果遇到“)”或“”就將其與棧頂?shù)睦ㄌ?hào)進(jìn)行匹配,如果匹配,就將棧頂?shù)淖罄ㄌ?hào)彈出,如果不匹配就將棧頂指針向下移動(dòng),直到所有的括號(hào)操作完成,如果棧為空,那么該表達(dá)式的括號(hào)是匹配的,否則括號(hào)不匹配。j=strlen(str);for(i=0;ij;i+)if(stri=(|stri=)push(s,str);for(i=0;ij;i+)if(stri=)if

3、(*s-top=()pop(s,&t);elsestop=s-top-1;if(stri=)if(*stop二二)pop(s,&t);elsestop=stop1;(4)你的應(yīng)用中采用的是順序的還是鏈?zhǔn)降拇鎯?chǔ)結(jié)構(gòu)?為什么要選用這種存儲(chǔ)結(jié)構(gòu)。答:我的應(yīng)用中采用的是順序的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu),因?yàn)閷?duì)于棧這種抽象的數(shù)據(jù)類型,有著“先進(jìn)后出”的特點(diǎn),這種特性和表達(dá)式中括號(hào)匹配的過程相符合,因此我采用了這種存儲(chǔ)結(jié)構(gòu)。(5)源程序的大致的執(zhí)行過程是怎樣的?答:先用編譯器編寫一個(gè).C的文件,然后編譯生成.Obj的文件,通過連接將目標(biāo)文件連接生成一個(gè).exe文件,之后運(yùn)行文件就可以執(zhí)行了。六、附錄(1)如果你對(duì)這個(gè)實(shí)

4、驗(yàn)還有其他的解決方案或設(shè)想,或?qū)ξ覀兊膶?shí)驗(yàn)方案有什么意見,請(qǐng)?jiān)诖嗣枋觥_@次實(shí)驗(yàn)提高了我對(duì)數(shù)據(jù)結(jié)構(gòu)中堆棧、隊(duì)列的理解,提高了我的編程能力,學(xué)校以后可以增加實(shí)驗(yàn)課的課時(shí),這樣我們可以更大程度的提高自己的編程能力。另外對(duì)于本實(shí)驗(yàn),我覺得我們還可以使用鏈表完成,鏈表中每個(gè)結(jié)點(diǎn)存儲(chǔ)的數(shù)據(jù)項(xiàng)內(nèi)容為括號(hào),從左導(dǎo)游掃描表達(dá)式,將所有的括號(hào)按照掃描的順序存成鏈表這種數(shù)據(jù)結(jié)構(gòu)之后,可以將第一個(gè)結(jié)點(diǎn)的內(nèi)容和最后一個(gè)結(jié)點(diǎn)的內(nèi)容比較,如果匹配則比較第二個(gè)和倒數(shù)第二個(gè),以此類推。否則輸出括號(hào)不匹配。(2)實(shí)驗(yàn)參考的資料數(shù)據(jù)結(jié)構(gòu)(第二版)閆玉寶編著清華大學(xué)出版社思考題(a)棧和隊(duì)列在計(jì)算機(jī)系統(tǒng)中有哪些應(yīng)用?寫出你知道的系統(tǒng)

5、中,這兩種抽象數(shù)據(jù)類型的應(yīng)用。答:在計(jì)算機(jī)系統(tǒng)中,使用棧的應(yīng)用有表達(dá)式的計(jì)算,迷宮以及括號(hào)匹配等。使用隊(duì)列的應(yīng)用有打印文檔,售票系統(tǒng),解決主機(jī)與外部設(shè)備之間速度不匹配問題,解決多用戶引起的資源競(jìng)爭(zhēng)問題等(b)在程序調(diào)用的時(shí)侯,需要進(jìn)行函數(shù)的切換,你認(rèn)為函數(shù)在進(jìn)行切換時(shí)系統(tǒng)要做那些工作?答:對(duì)于函數(shù)的切換,主要是一個(gè)壓棧的過程,先以一種約定的方式把參數(shù)壓棧,然后根據(jù)函數(shù)地址調(diào)用函數(shù),函數(shù)執(zhí)行后根據(jù)約定的方式出棧取得參數(shù)。選作:查詢以下內(nèi)容的有關(guān)知識(shí)a)函數(shù)調(diào)用、返回時(shí),系統(tǒng)對(duì)棧進(jìn)行的操作。答:函數(shù)調(diào)用時(shí)指令指針中的地址加1,指向函數(shù)調(diào)用后的下一條指令。這個(gè)地址隨后被放入堆棧,它將作為函數(shù)返回時(shí)的返回地址。在堆棧中為所聲明的返回值類型開辟空間。此時(shí)當(dāng)前的堆棧棧頂被記錄下來并存入一個(gè)稱為棧幀的特殊指針中,從現(xiàn)在開始到函數(shù)返回之前加入堆棧的任何數(shù)據(jù)都將被視為函數(shù)的局部變量。之后函數(shù)將所有形參放入堆棧,開始執(zhí)行指令指針中的指令。局部變量按其定義的方式壓入堆棧。當(dāng)函數(shù)準(zhǔn)備返回時(shí),返回值放入之前開辟的內(nèi)存中,隨后堆棧指針指向棧幀指針,從而彈出被調(diào)函數(shù)的所有局部變量。b)堆的管理都要做那些工作?具體怎樣做的?答:最小堆,將所有數(shù)據(jù)序列按完全

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論