![數(shù)據(jù)結(jié)構(gòu)與算法_第1頁](http://file4.renrendoc.com/view/b35f40baf29d042328782356d60d8d13/b35f40baf29d042328782356d60d8d131.gif)
![數(shù)據(jù)結(jié)構(gòu)與算法_第2頁](http://file4.renrendoc.com/view/b35f40baf29d042328782356d60d8d13/b35f40baf29d042328782356d60d8d132.gif)
![數(shù)據(jù)結(jié)構(gòu)與算法_第3頁](http://file4.renrendoc.com/view/b35f40baf29d042328782356d60d8d13/b35f40baf29d042328782356d60d8d133.gif)
![數(shù)據(jù)結(jié)構(gòu)與算法_第4頁](http://file4.renrendoc.com/view/b35f40baf29d042328782356d60d8d13/b35f40baf29d042328782356d60d8d134.gif)
![數(shù)據(jù)結(jié)構(gòu)與算法_第5頁](http://file4.renrendoc.com/view/b35f40baf29d042328782356d60d8d13/b35f40baf29d042328782356d60d8d135.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
數(shù)據(jù)結(jié)構(gòu)與算法數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第1頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第1頁。數(shù)據(jù)結(jié)構(gòu)實驗報告題目:線性表班級:網(wǎng)絡(luò)工程1401班學(xué)號:1408020106指導(dǎo)教師:高峰日期:2016/7/6數(shù)據(jù)結(jié)構(gòu)與算法全文共數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第2頁。實驗一:線性表一:實驗要求掌握數(shù)據(jù)結(jié)構(gòu)中線性表的基本概念。熟練掌握線性表的基本操作:創(chuàng)建、插入、刪除、查找、輸出、求長度及合并并運算在順序存儲結(jié)構(gòu)撒謊能夠的實驗。熟練掌握鏈表的各種操作和應(yīng)用。二.實驗內(nèi)容1.編程實現(xiàn)在順序存儲的有序表中插入一個元素(數(shù)據(jù)類型為整型)。2.編程實現(xiàn)把順序表中從i個元素開始的k個元素刪除(數(shù)據(jù)類型為整型)。三:實驗過程及步驟源代碼:#include<stdio.h>#include<malloc.h>#defineLIST_INIT_SIZE100#defineLISTINCREMENT10typedefstruct{int*elem;intlength;intlistsize;}SqList;//SqListsq;數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第3頁。voi數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第3頁。{sq->elem=(int*)malloc(LIST_INIT_SIZE*sizeof(int));sq->length=0;sq->listsize=LIST_INIT_SIZE;printf("---申請空間成功---!\n");}voidGetElem(SqList*sq,inti)//獲取第i位置元素的值{int*p;p=&(sq->elem[i-1]);printf("%d",*p);printf("\n");}intListInsert_Sq(SqList*sq,inti,inta)//在i位置之前插入a{int*p,*q;if(i<=0||i>sq->length+1){數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第4頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第4頁。return0;}if(sq->length>=sq->listsize){int*newbase=(int*)realloc(sq->elem,(sq->listsize+LISTINCREMENT)*sizeof(int));if(!newbase){printf("申請空間溢出\n");return0;}sq->elem=newbase;sq->listsize+=LISTINCREMENT;}p=&(sq->elem[i-1]);//p指向第i位置的元素q=&(sq->elem[sq->length-1]);//q指向最后一個元素for(;q>=p;--q)*(q+1)=*q;*p=a;++sq->length;數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第5頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第5頁。}intListDelete_Sq(SqList*sq,inti)//刪除i位置上的值{int*p,*q;if(i<1||i>sq->length)return0;p=&(sq->elem[i-1]);//p指向第i位置的元素q=sq->elem+sq->length-1;//q指向最后一個元素for(++p;p<=q;++p){*(p-1)=*p;}--sq->length;return1;}voidvisit(SqList*sq)//輸出數(shù)據(jù){inti=1;for(;i<=sq->length;i++){數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第6頁。int數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第6頁。p=&sq->elem[i-1];printf("%d",*p);printf("");}}voidmain(){inti=1,a=0,boo=1,number=0;SqLists,*sq;sq=&s;InitList_Sq(sq);printf("初始化空表\n");printf("輸入數(shù)據(jù)個數(shù):\n");scanf("%d",&number);printf("輸入%d個數(shù)據(jù):",number);printf("\n");for(;i<=number;i++){scanf("%d",&a);if(boo=ListInsert_Sq(sq,i,a)){數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第7頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第7頁。}else{printf("---插入不成功,重新插入---!\n");i=i-1;}}printf("輸出所有元素\n");visit(sq);printf("\n");printf("輸出刪除的位置:");scanf("%d",&a);if(boo=ListDelete_Sq(sq,a)){printf("---數(shù)據(jù)刪除成功!---\n");}else{printf("---沒有刪除成功---\n");}printf("輸出所有元素:\n");visit(sq);數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第8頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第8頁。printf("輸出要顯示數(shù)據(jù)的位置:");scanf("%d",&a);printf("輸出%d位置數(shù)值\n",a);if(a<0||a>sq->length){printf("---輸出位置的數(shù)據(jù)不存在---\n");}else{GetElem(sq,a);}}步驟:1.初始化空表2.順序插入數(shù)據(jù)后輸出所有元素3.選擇刪除位置,刪除數(shù)據(jù)后輸出所有元素4.選擇查看的數(shù)據(jù)位置,輸出選擇查看的數(shù)據(jù)數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第9頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第9頁。分析:本程序在實現(xiàn)順序存儲插入以及刪除i個元素開始的k個元素刪除(數(shù)據(jù)類型為整型)。之外在刪除、查看是實時輸出結(jié)果,并且可以查看希望顯示數(shù)據(jù)的位置。數(shù)據(jù)結(jié)構(gòu)與算法全文共數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第10頁。數(shù)據(jù)結(jié)構(gòu)實驗報告題目:樹班級:網(wǎng)絡(luò)工程1401班學(xué)號:1408020106指導(dǎo)教師:高峰日期:2016/7/6實驗二:樹一:實驗要求掌握二叉樹,二叉樹排序數(shù)的概念和存儲方法。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第11頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第11頁。熟練掌握編寫實現(xiàn)樹的各種運算的算法。二.實驗內(nèi)容統(tǒng)計一棵二叉樹中每種類型節(jié)點數(shù)(度為0/1/2的節(jié)點數(shù))。三:實驗過程及步驟#include<stdio.h>#include<malloc.h>#include<stdlib.h>typedefstructBitNode{intdata;structBitNode*lchild,*rchild;}BitNode,*BitTree;BitTreeBitTreeInit(){BitTreeBT;BT=(BitNode*)malloc(sizeof(BitNode));BT=NULL;returnBT;}BitTreeBitTreeCreat(BitTree&BT){intch;printf("請輸入節(jié)點的內(nèi)容,輸入0時結(jié)束建立!\n");scanf("%d",&ch);數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第12頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第12頁。BT=NULL;else{BT=(BitTree)malloc(sizeof(BitNode));BT->data=ch;BitTreeCreat(BT->lchild);BitTreeCreat(BT->rchild);}returnBT;}voidBitTreeEmpty(BitTreeBT){if(BT==NULL)printf("樹為空!\n");elseprintf("樹非空!\n");}voidPreOrderTraverse(BitTreeBT){if(BT!=NULL){printf("樹結(jié)點的內(nèi)容為:%d\n",BT->data);PreOrderTraverse(BT->lchild);數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第13頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第13頁。}}voidInOrderTraverse(BitTreeBT){if(BT!=NULL){InOrderTraverse(BT->lchild);printf("樹結(jié)點的內(nèi)容為:%d\n",BT->data);InOrderTraverse(BT->rchild);}}voidPostOrderTraverse(BitTreeBT){if(BT!=NULL){PostOrderTraverse(BT->lchild);PostOrderTraverse(BT->lchild);printf("樹結(jié)點的內(nèi)容為:%d\n",BT->data);}}intcount(BitTreeBT){if(BT==NULL)return0;數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第14頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第14頁。return(count(BT->lchild)+count(BT->rchild)+1);}intBinTreeDepth(BitTreeBT){inti=1,j=1;if(BT==NULL)return0;else{i=BinTreeDepth(BT->lchild);j=BinTreeDepth(BT->rchild);if(i>j)return(i+1);elsereturn(j+1);}}voidBinTreeClear(BitTree&BT){if(BT){if(BT->lchild)數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第15頁。數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第15頁。if(BT->rchild)BinTreeClear(BT->rchild);free(BT);BT=NULL;}}main(){inti=1,j,l;BitTreeBT;while(i!=0){printf("-----------------歡迎使用-------------------\n");printf("請選擇要進行的操作\n");printf("1.初始化一棵樹2.建立一棵樹3.判斷樹是否為空\n");printf("4.按前序遍歷樹5.按中序遍歷樹6.按后序遍歷樹\n");printf("7.求樹的深度8.求樹的結(jié)點數(shù)9.把樹清空\n");printf("0.退出操作界面\n");數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第16頁。printf("-----------------數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第16頁。scanf("%d",&j);switch(j){case1:BT=BitTreeInit();printf("樹已經(jīng)初始化!\n");break;case2:BitTreeCreat(BT);break;case3:BitTreeEmpty(BT);break;case4:PreOrderTraverse(BT);break;case5:InOrderTraverse(BT);break;case6:PostOrderTraverse(BT);break;case7:l=BinTreeDepth(BT);printf("樹的深度為:%d\n",l);break;case8:l=count(BT);printf("樹的結(jié)點數(shù)為:%d\n",l);break;數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第17頁。case9:B數(shù)據(jù)結(jié)構(gòu)與算法全文共19頁,當(dāng)前為第17頁。
溫馨提示
- 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)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 湖南冶金職業(yè)技術(shù)學(xué)院《視覺傳達設(shè)計基礎(chǔ)》2023-2024學(xué)年第二學(xué)期期末試卷
- 滄州職業(yè)技術(shù)學(xué)院《學(xué)科教學(xué)技能訓(xùn)練》2023-2024學(xué)年第二學(xué)期期末試卷
- 山東體育學(xué)院《景觀設(shè)計方法Ⅱ?qū)嵱?xùn)》2023-2024學(xué)年第二學(xué)期期末試卷
- 廣州東華職業(yè)學(xué)院《軟件工程倫理學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 重慶護理職業(yè)學(xué)院《素描著衣全身像》2023-2024學(xué)年第二學(xué)期期末試卷
- 合肥幼兒師范高等??茖W(xué)校《產(chǎn)品語義學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 哈爾濱科學(xué)技術(shù)職業(yè)學(xué)院《國際貿(mào)易與實務(wù)》2023-2024學(xué)年第二學(xué)期期末試卷
- 哈爾濱北方航空職業(yè)技術(shù)學(xué)院《中國文化概論》2023-2024學(xué)年第二學(xué)期期末試卷
- 武漢學(xué)院《問卷調(diào)查設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 昆明冶金高等??茖W(xué)?!渡鐣ぷ髡吲c法規(guī)》2023-2024學(xué)年第二學(xué)期期末試卷
- 通信工程制圖(微課版)課程標(biāo)準(zhǔn)
- 第三屆全國石油工程設(shè)計大賽作品(油藏工程設(shè)計單項)
- 壓力性損傷護理質(zhì)控細則及集束化管理措施
- 《批判性思維原理和方法》全套教學(xué)課件
- 高校輔導(dǎo)員招聘筆試試題及答案
- 產(chǎn)后康復(fù)-腹直肌分離
- 丙烯-危險化學(xué)品安全周知卡
- 2024-2030年中國免疫檢查點抑制劑行業(yè)市場研究分析及投資機會預(yù)測報告
- 《太常引·建康中秋夜為呂叔潛賦》示范課教學(xué)設(shè)計(部編人教版九年級語文下冊)
- 《配電網(wǎng)設(shè)施可靠性評價指標(biāo)導(dǎo)則》
- 2024年國家電網(wǎng)招聘之通信類題庫附參考答案(考試直接用)
評論
0/150
提交評論