版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、<p><b> 計算機工程學院</b></p><p><b> 課程設計報告</b></p><p> 課程名稱:數(shù)據(jù)結(jié)構(gòu)課程設計</p><p> 設計題目: 括號匹配問題 </p><p> 院 系:
2、 計算機工程學院 </p><p> 專 業(yè): </p><p> 組 別: </p><p> 學生姓名: 學 號: <
3、/p><p> 起止日期: 年月日 ~年月日 </p><p> 指導教師: </p><p><b> 目錄</b></p><p><b> 1.需求分析2</b></p><p> 1.1課程設計題目2</p>&
4、lt;p> 1.2 課程設計任務及要求2</p><p> 1.3 課程設計思想2</p><p> 1.4軟硬件運行環(huán)境及開發(fā)工具2</p><p><b> 1.概要設計2</b></p><p> 2.1課題設計的流程圖2</p><p> 2.2主要的數(shù)據(jù)結(jié)構(gòu)
5、3</p><p><b> 3.詳細設計4</b></p><p> 3.1課題設計的方法及原理4</p><p> 3.2主要代碼實現(xiàn)4</p><p> 4.調(diào)試與操作說明5</p><p><b> 5.總結(jié)與體會6</b></p>
6、<p><b> 6.致謝7</b></p><p><b> 7.參考文獻7</b></p><p><b> 1.需求分析</b></p><p><b> 1.1課程設計題目</b></p><p><b> 括號匹
7、配問題</b></p><p> 1.2 課程設計任務及要求</p><p> 假設一個算術表達式中可包含三種括號:圓括號,方括號和花括號且這三種括號可按任意次序嵌套使用。試利用棧的運算,編寫判別給定表達式中所含括號是否正確配對出現(xiàn)的算法。</p><p> 1.3 課程設計思想</p><p> 利用棧來判斷括號是否匹配
8、時,遇到左括號就進棧,遇到右括號則左括號出棧,代表這對括號匹配,如果右括號進棧時,棧為空,則說明缺少左括號,若表達式掃描完棧為空,則說明表達式的括號匹配,否則說明表達式缺少左括號。</p><p> 1.4軟硬件運行環(huán)境及開發(fā)工具</p><p> Microsoft visual C++ 6.0</p><p><b> 1.概要設計</b&
9、gt;</p><p> 2.1課題設計的流程圖</p><p> 2.2主要的數(shù)據(jù)結(jié)構(gòu)</p><p> 棧類包括如下數(shù)據(jù)成員和成員函數(shù)</p><p> top; //指向棧頂?shù)闹羔?LinkStack();
10、 //構(gòu)造函數(shù)</p><p> bool isEmpty(); //判斷棧是否為空</p><p> void Push(T x);//x進棧,top指向x</p><p> T Pop();//棧頂元素出棧</p><p> T GetPop(); / /讀取棧頂元素 bo
11、ol Search(T x); //搜素棧中是否有x這個元素 void OutPut(); //輸出棧內(nèi)所有元素</p><p><b> 3.詳細設計</b></p><p> 3.1課題設計的方法及原理</p><p> 1)定義三個棧 s1,s2,s3分別用來判斷
12、圓括號,方括號和花括號是否匹配</p><p> 2)對s1,s2,s3均有如下操作:</p><p> a.利用動態(tài)指針p依次對輸入的(字符串)表達式進行掃描</p><p> I.若為左括號,則進棧</p><p> II若為右括號,則先取棧頂元素。若棧頂元素為空,則缺少左括號;若不為空,則棧頂元素出棧</p>&l
13、t;p> b.當字符串掃描完,檢驗棧是否為空。若為空,則括號正確匹配。否則表示缺少右括號</p><p><b> 3.2主要代碼實現(xiàn)</b></p><p> sign1 ,sign2 ,sign3是分別用來標記棧是否為空</p><p> while(*p!='#')</p><p>&
14、lt;b> {</b></p><p> switch(*p)</p><p><b> {</b></p><p><b> case'(':</b></p><p> s1.Push(*p);</p><p><b>
15、 break;</b></p><p><b> case')':</b></p><p> if(s1.isEmpty())</p><p><b> {</b></p><p> sign1=false;</p><p> cout
16、<<"缺少'('"<<endl;</p><p><b> }</b></p><p><b> else</b></p><p><b> s1.Pop();</b></p><p><b> br
17、eak;</b></p><p><b> case'[':</b></p><p> s2.Push(*p);</p><p><b> break;</b></p><p><b> case']':</b></p&
18、gt;<p> if(s2.isEmpty())</p><p><b> {</b></p><p> sign2=false;</p><p> cout<<"缺少'['"<<endl;</p><p><b> }<
19、/b></p><p><b> else</b></p><p><b> s2.Pop();</b></p><p><b> break;</b></p><p><b> case'{':</b></p>
20、<p> s3.Push(*p);</p><p><b> break;</b></p><p><b> case'}':</b></p><p> if(s3.isEmpty())</p><p><b> {</b></p&g
21、t;<p> sign3=false;</p><p> cout<<"缺少'{'"<<endl;</p><p><b> }</b></p><p><b> else</b></p><p><b>
22、 s3.Pop();</b></p><p><b> break;</b></p><p><b> default:</b></p><p><b> break;</b></p><p><b> }</b></p>
23、<p><b> p++;</b></p><p><b> }</b></p><p><b> 4.調(diào)試與操作說明</b></p><p> 檢驗圓括號是否正確匹配</p><p> 檢驗方括號是否正確匹配</p><p>
24、綜合檢驗三種括號是否正確匹配</p><p><b> 5.總結(jié)與體會</b></p><p> 通過本次課程設計,我對棧有了更加深入的了解。雖然本次實驗只是利用棧解決了括號匹配問題,但是查閱關于棧的資料知道了利用棧的后進先出特點還能解決很多問題。例如利用??蓪⑦f歸算法轉(zhuǎn)化為非遞歸算法。此外棧還是系統(tǒng)實現(xiàn)嵌套調(diào)用機制的基礎。本實驗只解決了表達式中括號匹配問題,應再
25、改進判斷算數(shù)表達式是否合法。</p><p><b> 6.致謝</b></p><p><b> 。。。。。。</b></p><p><b> 7.參考文獻</b></p><p> 數(shù)據(jù)結(jié)構(gòu)(C++版)葉核亞 主編 機械工業(yè)出版社</p><p
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設計---括號匹配問題
- 數(shù)據(jù)結(jié)構(gòu)課程設計--數(shù)據(jù)結(jié)構(gòu)課程設計----huffman編碼
- 數(shù)據(jù)結(jié)構(gòu)課程設計(迷宮問題)
- 數(shù)據(jù)結(jié)構(gòu)課程設計迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設計--迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設計-迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)迷宮問題課程設計
- 數(shù)據(jù)結(jié)構(gòu)課程設計—迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設計---迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設計---迷宮問題
- 課程設計——數(shù)據(jù)結(jié)構(gòu)課程設計(八皇后問題)
- 數(shù)據(jù)結(jié)構(gòu)課程設計迷宮問題課程設計報告
- 迷宮問題——數(shù)據(jù)結(jié)構(gòu)課程設計迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設計(八皇后問題)
- 數(shù)據(jù)結(jié)構(gòu)課程設計---學生搭配問題
- 數(shù)據(jù)結(jié)構(gòu)課程設計---校園導航問題
- 數(shù)據(jù)結(jié)構(gòu)課程設計
- 數(shù)據(jù)結(jié)構(gòu)課程設計
- 數(shù)據(jù)結(jié)構(gòu)課程設計
- 數(shù)據(jù)結(jié)構(gòu)課程設計
評論
0/150
提交評論