版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第五次實驗報告——順序棧、鏈棧的插入和刪除一 需求分析1、在演示程序中,出現(xiàn)的元素以數(shù)字出現(xiàn)定義為 int 型,2、演示程序在計算機終端上,用戶在鍵盤上輸入演示程序中規(guī)定的運算命令,相應(yīng)的輸入數(shù)據(jù)和運算結(jié)果顯示在終端上3、順序棧的程序執(zhí)行的命令包括如下:1)定義結(jié)構(gòu)體2)順序棧的初始化及創(chuàng)建3)元素的插入4)元素的刪除5)順序棧的打印結(jié)果3、鏈棧的程序執(zhí)行的命令包括如下:1)定義結(jié)構(gòu)體2)鏈棧的初始化及創(chuàng)建3)元素的插入4)元素的刪除5)鏈棧的打印結(jié)果概要設(shè)計1、順序??赡苄枰玫接行虮淼某橄髷?shù)據(jù)類型定義:ADTList{數(shù)據(jù)對象 :D={ai|ai ∈ElemL,i=1,2,...,n,n ≥0}數(shù)據(jù)關(guān)系 :R1={<ai-1,ai>|ai-1,ai ∈D,i=2,...,n}基本操作:InitStack(SqStack&S)操作結(jié)果:構(gòu)造一個空棧Push(L,e)操作結(jié)果:插入元素 e為新的棧頂元素StatusPop(SqStack&S)操作結(jié)果:刪除棧頂元素}ADTList ;2、鏈??赡苄枰玫接行虮淼某橄髷?shù)據(jù)類型定義:ADTList{數(shù)據(jù)對象 :D={ai|ai ∈ElemL,i=1,2,...,n,n ≥0}數(shù)據(jù)關(guān)系 :R1={<ai-1,ai>|ai-1,ai ∈D,i=2,...,n}基本操作:LinkStack(SqStack&S)操作結(jié)果:構(gòu)造一個空棧StatusPush(L,e)操作結(jié)果:插入元素 e為新的棧頂元素StatusPop(SqStack&S)操作結(jié)果:刪除棧頂元素}ADTList ;3、順序棧程序包含的主要模塊:(1) 已給定的函數(shù)庫:2)順序棧結(jié)構(gòu)體:3)順序棧初始化及創(chuàng)建:(4) 元素插入(5) 元素刪除(6)主程序:、鏈棧程序包含的主要模塊:(1) 已給定的函數(shù)庫:2)鏈棧結(jié)構(gòu)體:3)鏈棧初始化及創(chuàng)建:(4) 元素插入(5) 元素刪除(6) 主程序:三 詳細設(shè)計線性棧:結(jié)構(gòu)體(邱建美)#defineSTACK_INIT_SIZE100// 存儲空間初始分配量#defineSTACKINCREMENT10// 存儲空間分配增量typedefstruct{int*base;// 在構(gòu)造棧之前和銷毀之后, base的值為 NULLint*top;// 棧頂指針intstacksize;// 當前已分配的存儲空間,以元素為單位}SqStack#include"Base.h"主函數(shù)(張濤)#include"construction.h"#include"stack_operation.c"intmain(){SqStackS;intchoice,e;S=InitStack();S=Input_Sq(S);printf(" 請選擇執(zhí)行的操作,輸入 1執(zhí)行入棧操作,輸入 2執(zhí)行出棧操作 choice=");scanf("%d",&choice);switch(choice){case1:{printf(" 請輸入插入元素的值 e=");scanf("%d",&e);S=Push(S,e);printf(" 執(zhí)行入棧操作后的線性棧為 ");Print_Stack(S);};break;case2:{S=Pop(S);printf(" 執(zhí)行出棧操作后的線性棧為 ");Print_Stack(S);};break;default:printf(" 您輸入的值不合法 ");}}線性棧的創(chuàng)建(鄭峰)SqStackInitStack()// 線性棧的創(chuàng)建{SqStackS;S.base=(int*)malloc(STACK_INIT_SIZE *sizeof(int));// 分配存儲空間if(!S.base)exit(OVERFLOW);// 存儲分配失敗S.top=S.base;S.stacksize=STACK_INIT_SIZE;returnS;}輸入函數(shù)(胡高飛)SqStackInput_Sq(SqStackS)// 輸入函數(shù){intn,i;printf(" 請輸入元素個數(shù) n=");scanf("%d",&n);printf(" 請輸入%d個元素",n);for(i=0;i<n;i++){scanf("%d",S.top);S.top++;}returnS;}進棧函數(shù)(鄭峰)SqStackPush(SqStackS,inte)//{
進棧函數(shù)if(S.top-S.base>=S.stacksize)//
判斷棧是否為滿, 追加存儲空間{S.base=(int*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(int));if(!S.base)exit(OVERFLOW);// 存儲分配失敗S.top=S.base+S.stacksize;S.stacksize+=STACKINCREMENT;}*S.top++=e;// 插入元素returnS;}出棧函數(shù)(邱建美)SqStackPop(SqStackS)// 刪除函數(shù){inte;if(S.top==S.base)printf(" 線性棧為空 ");e=*--S.top;returnS;}輸出函數(shù)(方傲俠)voidPrint_Stack(SqStackS)// 打印函數(shù){inti;while(S.base!=S.top){for(i=0;i<S.top-S.base;i++){S.top--;printf("%5d",*S.top);}printf("\n");}庫函數(shù)*Base.h( 程序名)*/#include<string.h>#include<ctype.h>#include<malloc.h>/*malloc() 等*/#include<limits.h>/*INT_MAX 等*/#include<stdio.h>/*EOF(=^Z 或F6),NULL*/#include<stdlib.h>/*atoi()*/#include<io.h>/*eof()*/#include<math.h>/*floor(),ceil(),abs()*/#include<process.h>/*exit()*//* 函數(shù)結(jié)果狀態(tài)代碼 */#defineTRUE1#defineFALSE0#defineOK1#defineERROR0#defineINFEASIBLE-1/*#defineOVERFLOW-2 因為在 math.h中已定義 OVERFLOW的值為3,故去掉此行 */typedefintStatus;/*Status 是函數(shù)的類型 ,其值是函數(shù)結(jié)果狀態(tài)代碼,如 OK等*/typedefintBoolean;/*Boolean 是布爾類型 ,其值是 TRUE或FALSEl鏈棧程序:結(jié)構(gòu)體(邱建美)typedefstructSNode// 建立鏈表結(jié)構(gòu)體{intdata;structSNode*next;}SNode,*LinkStack;主函數(shù)(方傲俠)#include"Base.h"#include"construction.h"#include"LinkStack_operation.c"intmain(){LinkStackS;intchoice,e;S=Creatlist_Stack();printf(" 請選擇執(zhí)行的操作,輸入 1執(zhí)行入棧操作,輸入 2執(zhí)行出棧操作 choice=");scanf("%d",&choice);switch(choice){case1:{printf(" 請輸入插入元素的值 e=");scanf("%d",&e);S=Push(S,e);printf(" 執(zhí)行操作入棧后的線性棧為 ");Print_Stack(S);};break;case2:{S=Pop(S);printf(" 執(zhí)行出棧操作后的線性棧為 ");Print_Stack(S);};break;default:printf(" 您輸入的值不合法 \n");}}創(chuàng)建鏈棧函數(shù)(張濤)LinkStackCreatlist_Stack()// 創(chuàng)建一個鏈棧{LinkStackS;LinkStackP;inti,n;S=(LinkStack)malloc(sizeof(SNode));S->next=NULL;/* 先建立一個鏈棧 */printf(" 請輸入元素個數(shù) n=");scanf("%d",&n);printf(" 請輸入%d個數(shù)據(jù)\n",n);i=0;scanf("%d",&S->data);for(i=1;i<n;++i){P=(LinkStack)malloc(sizeof(SNode));/*
生成新結(jié)點
*/P->next=S;S=P;scanf("%d",&S->data);/*
輸入元素值
*/}returnS;}入棧函數(shù)(方傲俠)LinkStackPush(LinkStackS,inte){LinkStackP;if(S==NULL)returnERROR;P=(LinkStack)malloc(sizeof(SNode));P->data=e;P->next=S;S=P;returnS;}出棧函數(shù)(胡高飛)LinkStackPop(LinkStackS){LinkStackP,Q;P=S;S=S->next;free(P);returnS;}輸出函數(shù)(鄭峰)voidPrint_Stack(LinkStackS){while(S){printf("%5d",S->data);S=S->next;}printf("\n");}庫函數(shù)*Base.h(程序名#include<string.h>#include<ctype.h>
)*/#include<malloc.h>/*malloc()
等
*/#include<limits.h>/*INT_MAX
等
*/#include<stdio.h>/*EOF(=^Z
或
F6),NULL*/#include<stdlib.h>/*atoi()*/#include<io.h>/*eof()*/#include<math.h>/*floor(),ceil(),abs()*/#include<process.h>/*exit()*//* 函數(shù)結(jié)果狀態(tài)代碼 */#defineTRUE1#defineFALSE0#defineOK1#defineERROR0#defineINFEASIBLE-1/*#defineOVERFLOW-2 因為在 math.h中已定義 OVERFLOW的值為3,故去掉此行 */typedefintStatus;/*Status 是函數(shù)的類型 ,其值是函數(shù)結(jié)果狀態(tài)代碼,如 OK等*/typedefintBoolean;/*Boolean 是布爾類型 ,其值是 TRUE或FALSEl四調(diào)試分析:輸出函數(shù)用了語句 S->next!=NULL改正:語句 S!=NULL五用戶手冊:看提示內(nèi)容六 測試結(jié)果線性棧:1)請輸入元素的個數(shù): 4,請輸入 4個數(shù)據(jù) 1234 ,請輸入執(zhí)行語句,選擇輸入 1執(zhí)行入棧操作,選擇輸入 2執(zhí)行出棧操作 choice=1,請輸入插入元素的值 e=6,執(zhí)行入棧操作后的線性棧為 643212)請輸入元素的個數(shù): 4,請輸入 4個數(shù)據(jù) 1234 ,請輸入執(zhí)行語句,選擇輸入 1執(zhí)行入棧操
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年全國名校??甲魑模骸翱慈艘创蠊?jié)與最好從小處著眼”
- 2024年度電磁兼容檢測技術(shù)服務(wù)合同3篇
- 移動軟件開發(fā)課程設(shè)計
- 班主任管理系統(tǒng)課程設(shè)計
- 洗瓶機課程設(shè)計凸輪設(shè)計
- 分動器課程設(shè)計
- 2024年離婚合同法律文本樣本版B版
- 2024年版房地產(chǎn)中介服務(wù)合同標的確認協(xié)議
- 2024年度單身公寓兩室一廳租賃托管服務(wù)合同3篇
- 熔煉爐車間課程設(shè)計
- 南充市市級事業(yè)單位2024年公招人員擬聘人員歷年管理單位遴選500模擬題附帶答案詳解
- 2024-2025學(xué)年上學(xué)期南京小學(xué)數(shù)學(xué)六年級期末模擬試卷
- 大學(xué)美育(同濟大學(xué)版)學(xué)習(xí)通超星期末考試答案章節(jié)答案2024年
- 2024年湖北省工業(yè)建筑集團有限公司招聘筆試參考題庫含答案解析
- 10000中國普通人名大全
- 疫情索賠公式及相應(yīng)表格模板Excel
- 下肢動脈血栓相關(guān)知識
- 夏令營活動日程安排表
- C30P8普通混凝土配合比報告
- 數(shù)獨“六宮”練習(xí)題
- 武廣高鐵路基常見病害案例解析
評論
0/150
提交評論