版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
電子科技大學軟件技術(shù)基礎(chǔ)上機實驗報告上機實驗三實驗名稱:ex3—1#include"stdio.h"#include"stdlib.h"#definetrue1#definefalse0typedefstructnode{ intdata; structnode*next;}node_type;typedefstruct{ node_type*top; intlength;}lstack_type;intpush(lstack_type*lp,intx){ node_type*p; p=(node_type*)malloc(sizeof(node_type)); if(p!=NULL){ p->data=x; p->next=lp->top; lp->top=p; }else return; }voidpop(lstack_type*lp){ node_type*p; if(lp->top==NULL) { return; } else { p=lp->top; lp->top=lp->top->next; free(p); }}node_type*print(node_type*head){ node_type*temp; temp=head; while(temp!=NULL){ printf("%d",temp->data); temp=temp->next;} }voidmain(){ inti,j; i=0;j=0; lstack_typeM,*lp; lp=&M; lp->top=NULL; printf("Pleaseinputthedata(endby'0'):\n"); scanf("%d",&i); while(i!=0) { push(lp,i); scanf("%d",&i); } printf("Alldatais:\n"); print(lp->top); printf("\nThefirstpop:\n"); pop(lp); print(lp->top); printf("\nThesecondpop:\n"); pop(lp); print(lp->top);}實際運行結(jié)果(如圖):心得體會:對于棧的程序還需多加練習和熟悉。實驗名稱:ex3—2#include"stdio.h"#defineMAXNUM20#definetrue1#definefalse0typedefstruct{intdata[MAXNUM]; intfront,rear;}queue_type;intenqueue(queue_type*q,intx){ if((q->rear+1)%MAXNUM==q->front) return(false); else { q->data[q->rear]=x; /*新元素入隊尾*/ q->rear=(q->rear+1)%MAXNUM;/*移rear*/ return(true); } }intdequeue(queue_type*q){ if(q->rear==q->front)/*判隊列是否為空*/ { printf("queueisempty"); return(0); /*返回空值*/ } else{ q->front=(q->front+1)%MAXNUM; return(q->data[q->front-1]); }}voidaa(queue_type*q){inti,j=0,k;i=dequeue(q);while(j<10){ if(i>0){ enqueue(q,i);j++; i=dequeue(q); }else{j++; i=dequeue(q); }}if(q->front>q->rear){ for(i=q->front;i<MAXNUM-1;i++){ printf("%d",q->data[i]);}for(i=0;i<q->rear;i++){ printf("%d",q->data[i]);}}else{ for(i=q->front-1;i<q->rear;i++){ printf("%d",q->data[i]);}}}voidmain(){queue_typeM,*lp; inti,j,a[]={2,3,-4,6,-5,8,-9,7,-10,20}; lp=&M; lp->front=0; lp->rear=0; for(i=0;i<10;i++) { enqueue(lp,a[i]); } printf("調(diào)用函數(shù)前隊列元素為:\n");for(i=0;i<10;i++){ printf("%d",lp->data[i]);}printf("\n調(diào)用函數(shù)后隊列元素為:\n");aa(lp);}實際運行結(jié)果(如圖):實驗名稱:ex3—3#include"stdio.h"#defineM20#definetrue1#definefalse0typedefstruct{intdata[M]; inttop1,top2; }stack_type;intpush1(stack_type*s){ intx; printf("請輸入數(shù)據(jù)(以’0‘結(jié)束):\n"); scanf("%d",&x); while(x!=0&&s->top1<=s->top2) { s->data[s->top1]=x; s->top1=s->top1+1; scanf("%d",&x); }if(s->top1==s->top2)printf("棧已滿!\n");return;}intpush2(stack_type*s){ intx; printf("請輸入數(shù)據(jù)(以’0‘結(jié)束):\n"); scanf("%d",&x); while(x!=0&&s->top1<=s->top2) { s->data[s->top2]=x; s->top2=s->top2-1; scanf("%d",&x); }if(s->top1==s->top2)printf("棧已滿!\n");return;}intpop1(stack_type*s){ intout; if(s->top1<0)return(false); else { out=s->data[s->top1-1]; s->top1=s->top1-1;return(out); }}intpop2(stack_type*s){ intout; if(s->top2>=M)return(false); else { out=s->data[s->top2+1]; s->top2=s->top2+1;return(out); }}voidmain(){ inti,j,k;stack_typeas,*lp; lp=&as; lp->top1=0; lp->top2=M-1; while(1) {printf("請選擇你要操作的棧:輸入“1”或“2”\n");printf("返回“0”\n");scanf("%d",&i);if(i==1) { printf("請選擇你要進行的操作:入?!?”;出?!?”\n");scanf("%d",&k);switch(k){ case1:push1(lp);break;case2:j=pop1(lp);printf("出棧元素為:%d\n",j);break;default:printf("輸入錯誤!\n");} } elseif(i==2) { printf("請選擇你要進行的操作:入棧“1”;出棧“2”\n");scanf("%d",&k);switch(k){ case1:push2(lp);break;case2:j=pop2(lp);printf("出棧元素為:%d\n",j);break;default:printf("輸入錯誤!\n");} } elsebreak;}}實際運行結(jié)果(如圖):程序名稱:ex3—4#include"stdio.h"#defineMAXNUM5#definetrue1#definefalse0typedefstruct{intdata[MAXNUM]; intfront,rear,tag;}queue_type;intenqueue(queue_type*q,intx){ q->data[q->rear]=x; q->rear=(q->rear+1)%MAXNUM; return(true); }intdequeue(queue_type*q){ if(q->rear==q->front&&q->tag==0) { printf("queueisempty"); return(0); } else{ q->front=(q->front+1)%MAXNUM; return(q->data[q->front-1]); }}voidmain(){queue_typeM,*lp; inti,j=0,k; lp=&M; lp->front=0; lp->rear=0; lp->tag=0; printf("請輸入元素(以-999結(jié)束):\n"); for(i=0;i<MAXNUM;i++) { scanf("%d",&k); if(k!=-999) { enqueue(lp,k); j++; lp->tag=2; if(j==MAXNUM) { lp->tag=1; printf("隊列已滿!\n"); break; } } else break; } printf("隊列元素為:\n");if(lp->front>=lp->rear){ for(i=lp->front;i<MAXNUM;i++)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 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年河北省公需課學習-《中華人民共和國著作權(quán)法》修訂解讀
- K008-個人知識管理
- 常識判斷對錯題庫及答案
- 官方教育機構(gòu)合同范本
- 2025年武侯區(qū)職高面試真題及答案
- 2025年珠海中考美術(shù)試卷及答案
- 燈具工程安裝合同范本
- 農(nóng)村土方購買合同范本
- 建材租賃工程合同范本
- 德陽房產(chǎn)買房合同范本
- 2025年度河北省機關(guān)事業(yè)單位技術(shù)工人晉升高級工考試練習題附正確答案
- 交通運輸布局及其對區(qū)域發(fā)展的影響課時教案
- 2025年中醫(yī)院護理核心制度理論知識考核試題及答案
- GB/T 17981-2025空氣調(diào)節(jié)系統(tǒng)經(jīng)濟運行
- 比亞迪儲能項目介紹
- 學堂在線 大數(shù)據(jù)與城市規(guī)劃 期末考試答案
- 中國歷史地理智慧樹知到期末考試答案章節(jié)答案2024年北京大學
- MOOC 跨文化交際通識通論-揚州大學 中國大學慕課答案
- GB/T 1048-2019管道元件公稱壓力的定義和選用
- 凱石量化對沖2號基金合同
- 電力現(xiàn)貨市場基本原理課件
評論
0/150
提交評論