




免費預覽已結束,剩余3頁可下載查看
下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
實驗二 棧一、實驗目的 1.了解棧的特性。 2.掌握棧的順序表示和實現。 3.掌握棧的鏈式表示和實現。二、實驗內容 實驗2.1棧的順序表示和實現 編寫一個程序實現順序棧的各種基本運算,并在此基礎上設計一個主程序,完成如下功能: (1)初始化順序棧。 (2)插入元素。 (3)刪除棧頂元素。 (4)取棧頂元素。 (5)遍歷順序棧。 (6)置空順序棧。 實驗2. 2棧的鏈式表示和實現 編寫一個程序實現鏈棧的各種基本運算,并在此基礎上設計一個主程序,完成如下功能: (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結束運行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(結束運行。再見!n);鏈式棧#include#includetypedef struct SNode int data; struct SNode *next;SNode,*Stack;typedef structStack top;int length;SqStack;/定義鏈式棧的結構體int InitStack(SqStack &S)S.top=NULL;S.length=0;return 0;/初始化鏈式棧int 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(鏈式隊列中的元素);p=S.top;if(S.top!=NULL)while(p!=NULL)printf(%5d,p-data);p=p-next;elseprintf(隊列為空n);printf(n);return 0;/遍歷鏈式棧int ClearStack(SqStack &S)S.top=NULL;printf(已置空鏈式棧);printf(n);return 0;/置空鏈式棧void main()SqStack S;int e,m;printf(n);printf(n);printf(n);printf(n);printf(1插入元素;2刪除元素;3返回棧頂元素4置空鏈式棧0結束運行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. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 棉花采購合同范本
- 車輛安全檢查合同范本
- 防腐分包合同范本
- 裝修合同范本提取公積金
- 賣房資金托管合同范本
- 酒吧轉讓終止合同范本
- 奧迪融資購車合同范本
- 住宅裝修合同范本簡單
- 胰腺癌患者護理查房
- 員工離職原因及解決方案培訓課件
- 體檢檢后服務工作方案
- 大格子作文紙模板
- 西師大版五年級音樂上冊 第一單元《走街街》 課件走 街 街
- 《建設監(jiān)理導論04230》自考復習考試題庫大全-下(填空、簡答題匯總)
- MPW系列變頻張緊絞車介紹
- 農家樂安全應急預案
- invt英威騰CHF100A變頻器說明書
- 社會主義經濟理論習題與答案
- 2023年天津市普通高中學業(yè)水平考試地理試題(含答案)
- 小學優(yōu)秀傳統(tǒng)文化教育總結模板(2篇)
- 生物技術概論
評論
0/150
提交評論