![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)——棧(附程序).doc_第1頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-3/14/0ef7d570-2b0d-45c3-97aa-5a5c02b49898/0ef7d570-2b0d-45c3-97aa-5a5c02b498981.gif)
![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)——棧(附程序).doc_第2頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-3/14/0ef7d570-2b0d-45c3-97aa-5a5c02b49898/0ef7d570-2b0d-45c3-97aa-5a5c02b498982.gif)
![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)——棧(附程序).doc_第3頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-3/14/0ef7d570-2b0d-45c3-97aa-5a5c02b49898/0ef7d570-2b0d-45c3-97aa-5a5c02b498983.gif)
![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)——棧(附程序).doc_第4頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-3/14/0ef7d570-2b0d-45c3-97aa-5a5c02b49898/0ef7d570-2b0d-45c3-97aa-5a5c02b498984.gif)
![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)——棧(附程序).doc_第5頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-3/14/0ef7d570-2b0d-45c3-97aa-5a5c02b49898/0ef7d570-2b0d-45c3-97aa-5a5c02b498985.gif)
免費(fèi)預(yù)覽已結(jié)束,剩余3頁(yè)可下載查看
下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
實(shí)驗(yàn)二 棧一、實(shí)驗(yàn)?zāi)康?1.了解棧的特性。 2.掌握棧的順序表示和實(shí)現(xiàn)。 3.掌握棧的鏈?zhǔn)奖硎竞蛯?shí)現(xiàn)。二、實(shí)驗(yàn)內(nèi)容 實(shí)驗(yàn)2.1棧的順序表示和實(shí)現(xiàn) 編寫(xiě)一個(gè)程序?qū)崿F(xiàn)順序棧的各種基本運(yùn)算,并在此基礎(chǔ)上設(shè)計(jì)一個(gè)主程序,完成如下功能: (1)初始化順序棧。 (2)插入元素。 (3)刪除棧頂元素。 (4)取棧頂元素。 (5)遍歷順序棧。 (6)置空順序棧。 實(shí)驗(yàn)2. 2棧的鏈?zhǔn)奖硎竞蛯?shí)現(xiàn) 編寫(xiě)一個(gè)程序?qū)崿F(xiàn)鏈棧的各種基本運(yùn)算,并在此基礎(chǔ)上設(shè)計(jì)一個(gè)主程序,完成如下功能: (1)初始化鏈棧。 (2)鏈棧置空。 (3)入棧。 (4)出棧。 (5)取棧頂元素。 (6)遍歷鏈棧。 順序棧#include#include#define STACK_INIT_SIZE 100#define STACKINCREMENT 10typedef structint *base;int *top;int stacksize;SqStack;int InitStack(SqStack &S)S.base=(int*)malloc(STACK_INIT_SIZE*sizeof(int);if(!S.base)exit(0);S.top=S.base;S.stacksize=STACK_INIT_SIZE;return 0;/初始化順序棧int Push(SqStack &S,int e)if(S.top-S.base=S.stacksize)S.base=(int *)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(int);if(!S.base)exit(0);S.top=S.base+S.stacksize;S.stacksize+=STACKINCREMENT;*S.top+=e;return 0;/插入元素eint Pop(SqStack &S,int e)if(S.top=S.base)return 0;e=*-S.top;printf(刪除的棧頂元素%5d,e);printf(n);return 0;/刪除棧頂元素eint Gettop(SqStack &S,int e)if(S.top=S.base)return 0;e=*(S.top-1);printf(返回的棧頂元素%5d,e);printf(n);return 0;/返回棧頂元素evoid PrintStack(SqStack &S) int *k; printf(順序棧中的元素:n); for(k=S.base;k!=S.top;k+)printf(%5d,*k); printf(n);/遍歷順序棧void ClearStack(SqStack &S)S.top=S.base;/置空順序棧void main()int e,i,n; SqStack S;InitStack(S);printf(1插入頂元素;2刪除頂元素;3返回頂元素;4置空順序棧;0結(jié)束運(yùn)行n); printf(n);printf(n);printf(n); printf(n);printf(n); printf(選擇: ); scanf(%d,&n);printf(n);printf(n); while(n!=0) switch(n) case 1:printf(插入棧頂元素);scanf(%d,&e);Push(S,e);PrintStack(S);printf(n);printf(n);break;case 2:Pop(S,e);PrintStack(S);printf(n);printf(n);break;case 3:Gettop(S,e);printf(n);printf(n);break;case 4:printf(已置空順序棧);ClearStack(S);printf(n);printf(n);break; printf(選擇: );scanf(%d,&n);printf(n);printf(n); printf(結(jié)束運(yùn)行。再見(jiàn)!n);鏈?zhǔn)綏?include#includetypedef struct SNode int data; struct SNode *next;SNode,*Stack;typedef structStack top;int length;SqStack;/定義鏈?zhǔn)綏5慕Y(jié)構(gòu)體int InitStack(SqStack &S)S.top=NULL;S.length=0;return 0;/初始化鏈?zhǔn)綏nt Push(SqStack &S,int e)Stack p;p=(Stack)malloc(sizeof(SNode);if(!p)exit(0);p-data=e;p-next=S.top;S.top=p;S.length+;return 0;/插入元素eint Pop(SqStack &S)if(!S.top)return 0;elseStack q;q=S.top;S.top=S.top-next;-S.length;free(q); return 0;/刪除棧頂元素eint GetTop(SqStack &S)if(!S.top)return 0;elseprintf(返回棧頂元素%5dn,S.top-data);return 0;/返回棧頂元素int PrintStack(SqStack &S)Stack p;printf(鏈?zhǔn)疥?duì)列中的元素);p=S.top;if(S.top!=NULL)while(p!=NULL)printf(%5d,p-data);p=p-next;elseprintf(隊(duì)列為空n);printf(n);return 0;/遍歷鏈?zhǔn)綏nt ClearStack(SqStack &S)S.top=NULL;printf(已置空鏈?zhǔn)綏?;printf(n);return 0;/置空鏈?zhǔn)綏oid main()SqStack S;int e,m;printf(n);printf(n);printf(n);printf(n);printf(1插入元素;2刪除元素;3返回棧頂元素4置空鏈?zhǔn)綏?結(jié)束運(yùn)行n);printf(n);printf(n);printf(n);InitStack(S); printf(n);printf(n);printf(選擇: ); scanf(%d,&m);printf(n);printf(n); while(m!=0) switch(m) case 1:printf(插入元素:);scanf(%d,&e);Push(S,e);PrintStack(S);printf(n);printf(n);break;case 2:Pop(S);PrintStack(S);printf(n);printf(n);break;case 3:
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 國(guó)慶節(jié)聯(lián)誼活動(dòng)方案
- 現(xiàn)代經(jīng)濟(jì)環(huán)境下的市場(chǎng)動(dòng)態(tài)與趨勢(shì)分析
- 弱電施工方案范本
- 1 有余數(shù)的除法 第二課時(shí)(說(shuō)課稿)-2023-2024學(xué)年二年級(jí)下冊(cè)數(shù)學(xué)蘇教版
- 2023三年級(jí)英語(yǔ)下冊(cè) Unit 1 My Body第1課時(shí)說(shuō)課稿 陜旅版(三起)
- 6 有多少浪費(fèi)本可避免 第一課時(shí) 說(shuō)課稿-2023-2024學(xué)年道德與法治四年級(jí)下冊(cè)統(tǒng)編版001
- 2024年八年級(jí)物理下冊(cè) 12.1杠桿說(shuō)課稿 (新版)新人教版001
- 《14學(xué)習(xí)有方法》(說(shuō)課稿)-部編版(五四制)道德與法治二年級(jí)下冊(cè)
- 2023九年級(jí)語(yǔ)文下冊(cè) 第三單元 11 送東陽(yáng)馬生序說(shuō)課稿 新人教版001
- Unit8 We're twins(說(shuō)課稿)-2023-2024學(xué)年譯林版(三起)英語(yǔ)三年級(jí)下冊(cè)
- 親歷電子病歷系統(tǒng)分級(jí)評(píng)價(jià)四級(jí)參評(píng)紀(jì)實(shí)-2022醫(yī)院信息化
- 凸優(yōu)化在經(jīng)濟(jì)學(xué)與金融學(xué)中的應(yīng)用
- 【鋼鐵冶煉】-銻冶煉先關(guān)工藝
- 漸變方格模板
- 大學(xué)生職業(yè)生涯發(fā)展規(guī)劃知到章節(jié)答案智慧樹(shù)2023年齊魯師范學(xué)院
- 環(huán)境因素匯總識(shí)別及評(píng)價(jià)表(保衛(wèi)部 )
- GB/T 9123.1-2000平面突面鋼制管法蘭蓋
- 元代文學(xué)-緒論課件
- 2023年版勞動(dòng)實(shí)踐河北科學(xué)技術(shù)出版社一年級(jí)下冊(cè)全冊(cè)教案
- 方案報(bào)審表(樣表)
- pp顧問(wèn)的常見(jiàn)面試問(wèn)題
評(píng)論
0/150
提交評(píng)論