版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
實(shí)驗(yàn)一、線性表的實(shí)現(xiàn)及操作(一)一、 實(shí)驗(yàn)?zāi)康牧私夂驼莆站€性表的順序存儲(chǔ)結(jié)構(gòu);掌握用C語言上機(jī)調(diào)試線性表的基本方法;掌握線性表的基本操作:插入、刪除、查找以及線性表合并等運(yùn)算在順序存儲(chǔ)結(jié)構(gòu)和鏈接存儲(chǔ)結(jié)構(gòu)上的運(yùn)算,以及對(duì)相應(yīng)算法的性能分析。二、 實(shí)驗(yàn)要求給冷一段程序代碼,程序代碼所完成的功能為:(1)建立一個(gè)線性表;(2)依次輸入數(shù)據(jù)元素1,2,3,4,5,6,7,8,9,10;(3)刪除數(shù)據(jù)元素5;(4)依次顯示當(dāng)前線性表中的數(shù)據(jù)元素。假設(shè)該線性表的數(shù)據(jù)元素個(gè)數(shù)在最壞情況下不會(huì)超過100個(gè),要求使用順序表。程序中有3處錯(cuò)誤的地方,有標(biāo)識(shí),屬于邏輯錯(cuò)誤,對(duì)照書中的代碼仔細(xì)分析后,要求同學(xué)們修改錯(cuò)誤的代碼,修改后上機(jī)調(diào)試得到正確的運(yùn)行結(jié)果。需求分析:這份實(shí)驗(yàn)報(bào)告為所有必做題的實(shí)驗(yàn)報(bào)告。包括實(shí)驗(yàn)一順序表建立、插入、刪除等基本操作,實(shí)驗(yàn)二單鏈表的建立、插入、刪除等基本操作,實(shí)驗(yàn)四二叉樹的基本操作:樹的建立、前序、中序、后序遍歷及實(shí)驗(yàn)六圖的遍歷:深度優(yōu)先和廣度優(yōu)先。這四份基礎(chǔ)性的實(shí)驗(yàn)為改錯(cuò)性質(zhì),將每個(gè)實(shí)驗(yàn)題目中的錯(cuò)誤改正過來并通過調(diào)試,有助于對(duì)基礎(chǔ)知識(shí)的理解與強(qiáng)化記憶。概要設(shè)計(jì):實(shí)驗(yàn)一為對(duì)順序線性表實(shí)現(xiàn)插入,刪除,查找等基本操作。需要用到的語句包括voidListIiiitiate(SeqList*L)iiitListIiisert(SeqList*L.iiiti,DataTvpex)mtListDelete(SeqList*L,mti,DataT^e*x)mtListGet(SeqListL,mti.DataTvpe*x)等。實(shí)驗(yàn)二是對(duì)單鏈表進(jìn)行建立,插入,刪除等基本操作。需要的語句為voidListInitiate(SeqList*L)mtListIiisert(SeqList*L.iiiti,DataTypex)mtListDelete(SeqList*L,mti.DataType*x)mtListGet(SeqListL,mti,DataType*x)等。實(shí)驗(yàn)四為二叉樹,要求建立一個(gè)二叉樹,并實(shí)現(xiàn)前序,中序及后序的遍歷。所需語句包括voidListInitiate(SeqList*L)mtListIiisert(SeqList*L.iiiti,DataTypex)mtListDelete(SeqList*L,mti.DataType*x)mtListGet(SeqListL,mti,DataType*x)等。實(shí)驗(yàn)六的內(nèi)容是圖的遍歷包括鄰接矩陣和鄰接鏈表兩種方法。三、程序代碼(更正后的代碼)
#include<stdio.h>#defineMaxSize100tvpedefintDataType;tvpedefstnict{DataTypelist[MaxSize];intsize;}SeqList;voidListhutiate(SeqList*L){L->size=0;mtListLengtli(SeqListL){letumL.size;/*voidListhutiate(SeqList*L){L->size=0;mtListLengtli(SeqListL){letumL.size;/*定義初始數(shù)據(jù)元素個(gè)數(shù)*//*返回順序表L的當(dāng)前數(shù)據(jù)元素個(gè)數(shù)*/mtListhiseit(SeqList*L,int1,DataTypex)/*在順序表L的位置i(0W1Wsize)前插入數(shù)據(jù)元素值x*/嚴(yán)插入成功返回1,插入失敗返1?10*/mtj;if(L->size>=MaxSize){pnntf(”順序表己滿無法插入!E);letum0;}elseif(i<0||i>L->size){piintfC,參數(shù)1不合法!\n”);letum0;}elsefbi(j=L->size;j>i;j-)L->list[j]=L->list[j]; /*為插入做準(zhǔn)備*/L->list[i]=x; /*插入*/L->size卄; /*元素個(gè)數(shù)加1*/leturn1;mtListDelete(SeqList*L,mti,DataTvpe*x)嚴(yán)刪除順序表L中位置i(0WiWsize-1)的數(shù)據(jù)元素值并存放到參數(shù)x中*/嚴(yán)刪除成功返回1,刪除失敗返1?10*/mtj;if(L->size<=0){piintf("順序表己空無數(shù)據(jù)元素可刪!\n“);letuin0;}elseif(i<0||1>L->size-l){piintfC*參數(shù)1不合法”);letuin0;}else{//此段程序有一處錯(cuò)誤*x=L->list[i]; /*保存刪除的元素到參數(shù)x中*/foi(j=i+l;j<=L->size-l;j++)L->list[j]=L->list[j-l]; /*依次前移L->size-; /*數(shù)據(jù)元素個(gè)數(shù)減1*/letuin1;}}mtListGet(SeqListL,inti,DataTvpe*x)嚴(yán)取順序表L中第「?jìng)€(gè)數(shù)據(jù)元素於]值存于x中,成功則返回1,失敗返{if(i<O||i>L.size-l){pnntf(n參數(shù)1不合法!\ii");letuin0;}else{*x=L.list[i];letuin1;}}voidmain(void)SeqListmvList;lilt1、x;Listlmtiate(&myList);fbi(i=0;i<10;i++)ListLisert(&mvList,i,1十1);ListDelete(&myLis「4,&x);foi(i=0;i<ListLength(myList);i++){?ListGet(myList,1,&x);//此段程序有一處錯(cuò)誤piintf(n%d”,x);}}測(cè)試結(jié)果:1 23455555Pressanykeytocontinue線性表的實(shí)現(xiàn)及操作(二)一、 實(shí)驗(yàn)?zāi)康牧私夂驼莆站€性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu);掌握用C語言上機(jī)調(diào)試線性表的基本方法;掌握線性表的基本操作:插入、刪除、查找以及線性表合并等運(yùn)算在順序存儲(chǔ)結(jié)構(gòu)和鏈接存儲(chǔ)結(jié)構(gòu)上的運(yùn)算,以及對(duì)相應(yīng)算法的性能分析。二、 實(shí)驗(yàn)要求給定一段程序代碼,程序代碼所完成的功能為:(1)建立一個(gè)線性表;(2)依次輸入數(shù)據(jù)元素1,2,3,4僅6,7,&9,10:(3)刪除數(shù)據(jù)元素5;(4)依次顯示當(dāng)前線性表中的數(shù)據(jù)元素。假設(shè)該線性表的數(shù)據(jù)元素個(gè)數(shù)在最壞情況下不會(huì)超過100個(gè),要求使用單鏈表。程序中有3處錯(cuò)誤的地方,有標(biāo)識(shí),屬于邏輯錯(cuò)誤,對(duì)照書中的代碼仔細(xì)分析后,要求同學(xué)們修改錯(cuò)誤的代碼,上機(jī)調(diào)試并得到正確的運(yùn)行結(jié)果。三、程序代碼:(更正后的結(jié)果)存include<stdio.h>存include<stdlib.h>存inchide<malloc.h>/*該文件包含pnngtft)等函數(shù)*//*該文件包含exit。等函數(shù)*//*該文件包含malloc()等函數(shù)*/typedefmtDataTvpe;/*定義DataType為iiit*/typedefstmctNodeiDataTypedata;stmctNode*next;}SLNode;嚴(yán)初始化*7嚴(yán)初始化*7嚴(yán)如果有內(nèi)存空間,申請(qǐng)頭結(jié)點(diǎn)空間并使頭指針head指向頭結(jié)點(diǎn)引if((*head=(SLNode*)malloc(sizeof(SLNode)))=NULL)exit(l);(*head)->next=NULL; 嚴(yán)置鏈尾標(biāo)記NULL*/}/*p指向首元結(jié)點(diǎn)嚴(yán)/*p指向首元結(jié)點(diǎn)嚴(yán)size初始為0*/SLNode*p=head;mtsize=0;
嚴(yán)循壞計(jì)數(shù)可while(p->next!=NULL){嚴(yán)循壞計(jì)數(shù)可p=p->next;size++;}returnsize;}intListIiiseil(SLNode*head.iiiti.DataTypex)/*在帶頭結(jié)點(diǎn)的單鏈表head的數(shù)據(jù)元素ai(0WiWsize)結(jié)點(diǎn)前*//*插入一個(gè)存放數(shù)據(jù)元素x的結(jié)點(diǎn)*/{SLNode*p,*q;mtj;p=head; /*p指向首元結(jié)點(diǎn)*/j=-l; /*j初始為-1*/while(p->next!=NULL&&j<i-1)/*最終讓指針p指向數(shù)據(jù)元素ai-1結(jié)點(diǎn)*/{p=p->next;J卄;}W){pnntf(“插入位置參數(shù)錯(cuò)!”);return0;嚴(yán)生成新結(jié)點(diǎn)由指針q指示if((q=(SLNode*)inalloc(sizeof(SLNode)))=NULL)exit(l);q->data=x;〃此段程序有一處錯(cuò)誤p->next〃此段程序有一處錯(cuò)誤p->next=q->next;p->next=q;return1;}/*給指針q>next賦值*/嚴(yán)給指針p->next重新賦值可intListDelete(SLNode*head,mti,DataTvpe*x)/*intListDelete(SLNode*head,mti,DataTvpe*x)/*刪除帶頭結(jié)點(diǎn)的單鏈表head的數(shù)據(jù)元素ai(0WiWsize-1)結(jié)點(diǎn)*//*刪除結(jié)點(diǎn)的數(shù)據(jù)元素域值由x帶回。刪除成功時(shí)返回1;失敗返回0*/SLNode*p,*s;mtj;p=head; /*p指向首元結(jié)點(diǎn)*7J=-l; /*J初始為-1*/while(p->next!=NULL&&p->next->next!=NULL&&j<i-1)/*最終讓指針p指向數(shù)據(jù)元素ai-1結(jié)點(diǎn)*/{p=p->next;j++;}W){pnntf(“插入位置參數(shù)錯(cuò)!”);return0;〃此段程序有一處錯(cuò)誤s=p->next;*x=s->data;p->next=s->next;fiee(s);return1;}/*s=p->next;*x=s->data;p->next=s->next;fiee(s);return1;}/*把指針s所指結(jié)點(diǎn)的數(shù)據(jù)元素域值賦予X*//*把數(shù)據(jù)元素ai結(jié)點(diǎn)從單鏈表中刪除指*//*釋放指針s所指結(jié)點(diǎn)的內(nèi)存空間可intListGet(SLNode*head,mti,DataType*x)/*取數(shù)據(jù)元素ai和刪除函數(shù)類同,只是不刪除數(shù)據(jù)元素ai結(jié)點(diǎn)*/{SLNode*p;mtj;p=head;J=-l;while(p->next!=NULL&&j<i){P=p->next;j++;}pnntfC取元素位置參數(shù)錯(cuò)!”);return0;〃此段程序有一處錯(cuò)誤*x=p->data;return1;}voidDestroy(SLNode**head){SLNode*p,*pl;p=*head;xvhile(p!=NULL){pl=p;p=p->next;fiee(pl);}*head=NULL;voidniaiii(void){SLNode*head;iiiti,x;Listliiitiate(&head); /*初始化*/for(i=0;i<10;i++){if(ListIiisert(head,i,i+1)==0) /*
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 電纜企業(yè)合同范例
- 生產(chǎn)供水合同范例
- 買房定金協(xié)議合同范例
- 玻璃切割合同范例
- 小區(qū)收購(gòu)合同范例
- 工程合同變更服務(wù)合同范例
- 用工合同范例保密協(xié)議
- 網(wǎng)絡(luò)車輛抵押合同范例
- 結(jié)婚后財(cái)產(chǎn)分配合同范例
- 養(yǎng)豬用地合同范例
- 美團(tuán)合作協(xié)議書范本(2024版)
- 第21課《小圣施威降大圣》課件 2024-2025學(xué)年統(tǒng)編版語文七年級(jí)上冊(cè)
- 新疆喀什地區(qū)2024屆九年級(jí)下學(xué)期中考三模數(shù)學(xué)試卷(含解析)
- 高脂血癥性胰腺炎的治療與護(hù)理
- 個(gè)人推廣費(fèi)合同范本
- AQ/T 2061-2018 金屬非金屬地下礦山防治水安全技術(shù)規(guī)范(正式版)
- 天津市部分區(qū)2022-2023學(xué)年七年級(jí)上學(xué)期期末練習(xí)生物試題
- 小學(xué)三年級(jí)-安全知識(shí)考試試題-(附答案)-
- 醫(yī)院門診醫(yī)生績(jī)效考核標(biāo)準(zhǔn)及評(píng)分細(xì)則
- 重慶地鐵工程項(xiàng)目管理策劃書
- MOOC 體育保健學(xué)-江西財(cái)經(jīng)大學(xué) 中國(guó)大學(xué)慕課答案
評(píng)論
0/150
提交評(píng)論