大數(shù)據(jù)結(jié)構(gòu)線性表應(yīng)用_第1頁
大數(shù)據(jù)結(jié)構(gòu)線性表應(yīng)用_第2頁
大數(shù)據(jù)結(jié)構(gòu)線性表應(yīng)用_第3頁
已閱讀5頁,還剩18頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、實(shí)驗(yàn)一線性表應(yīng)用一.實(shí)驗(yàn)?zāi)康?、掌握用Turbo C或VC+吐機(jī)調(diào)試線性表的基本方法;2、 掌握線性表的基本操作,如插入、刪除、查找,以及線性表合并等運(yùn)算在順序存儲結(jié)構(gòu)和 鏈?zhǔn)酱鎯Y(jié)構(gòu)上的運(yùn)算;并能夠運(yùn)用線性表基本操作解決問題,實(shí)現(xiàn)相應(yīng)算法。二.實(shí)驗(yàn)學(xué)時(shí):課實(shí)驗(yàn)學(xué)時(shí):2學(xué)時(shí)課外實(shí)驗(yàn)學(xué)時(shí):4學(xué)時(shí)三備選實(shí)驗(yàn)題目1. 單鏈表基本操作練習(xí)(實(shí)驗(yàn)類型:驗(yàn)證型)1)問題描述:在主程序中設(shè)計(jì)一個(gè)簡單的菜單,分別調(diào)用相應(yīng)的函數(shù)功能:1 建立鏈表2 連接鏈表3 輸出鏈表0結(jié)束2)實(shí)驗(yàn)要求:在程序中定義下述函數(shù),并實(shí)現(xiàn)所要求的函數(shù)功能:CreateLinklist():從鍵盤輸入數(shù)據(jù),創(chuàng)建一個(gè)單鏈表ContLin

2、klist():將前面建立的兩個(gè)單鏈表首尾相連OutputLi nklist():輸出顯示單鏈表3)實(shí)驗(yàn)提示:單鏈表數(shù)據(jù)類型定義(C語言)# in elude <stdio.h>typedef int ElemType; / 元素類型typedef struct LNode ElemType data;struct LNode *n ext;LNode,*Li nkList;為了算法實(shí)現(xiàn)簡單,最好采用帶頭結(jié)點(diǎn)的單向鏈表。4)注意問題重點(diǎn)理解鏈?zhǔn)酱鎯Φ奶攸c(diǎn)及指針的含義。 注意比較順序存儲與鏈?zhǔn)酱鎯Φ母髯蕴攸c(diǎn)。注意比較帶頭結(jié)點(diǎn)、無頭結(jié)點(diǎn)鏈表實(shí)現(xiàn)插入、刪除算法時(shí)的區(qū)別。 單鏈表的操作是數(shù)

3、據(jù)結(jié)構(gòu)的基礎(chǔ),一定要注意對這部分的常見算法的理解。2. 順序表基本操作練習(xí)(實(shí)驗(yàn)類型:驗(yàn)證型)1)問題描述:從鍵盤輸入一組整型元素序列,建立順序表。實(shí)現(xiàn)該順序表的遍歷。在該順序表中進(jìn)行順序查找某一元素,查找成功返回1,否則返回0。判斷該順序表中元素是否對稱,對稱返回1,否則返回0。2)實(shí)驗(yàn)要求:對應(yīng)問題描述,在程序中定義4個(gè)相應(yīng)的函數(shù),實(shí)現(xiàn)上面要求的函數(shù)功能:在主程序中設(shè)計(jì)一個(gè)簡單的菜單,調(diào)用上述4個(gè)函數(shù)3)實(shí)驗(yàn)提示:順序表存儲數(shù)據(jù)類型定義(C語言)# define MAXSIZE 100 /表中元素的最大個(gè)數(shù)typedef int ElemType; / 元素類型typedef struct

4、 listElemType elemMAXSIZE; /靜態(tài)線性表in t le ngth; II表的實(shí)際長度SqList; II順序表的類型名4)注意問題:插入、刪除時(shí)元素的移動原因、方向及先后順序。理解不同的函數(shù)形參與實(shí)參的傳遞關(guān)系。3. 約瑟夫環(huán)問題(實(shí)驗(yàn)類型:綜合型)1) 問題描述:有編號為1,2n的n個(gè)人按順時(shí)針方向圍坐一圈,每人持有一個(gè)正整數(shù)密碼。開始給定一個(gè)正整數(shù) m,從第一個(gè)人按順時(shí)針方向自 1開始報(bào)數(shù),報(bào)到 m者出列,不再參加報(bào) 數(shù),這時(shí)將出列者的密碼作為 m,從出列者順時(shí)針方向的下一人開始重新自1開始報(bào)數(shù)。如此下去,直到所有人都出列。試設(shè)計(jì)算法,輸出出列者的序列。2)實(shí)驗(yàn)要

5、求:采用順序和鏈?zhǔn)絻煞N存儲結(jié)構(gòu)實(shí)現(xiàn)3)實(shí)現(xiàn)提示:用順序表來存儲圍座者的序號和密碼(順序存儲結(jié)構(gòu)).用number和code分別表示圍座者的序號和密碼 .假設(shè)圍座者人數(shù)為j,當(dāng)前使 用密碼為m,開始報(bào)數(shù)者位置為 s,那么下一出列者位置為 s=(s+m-1) mod j.當(dāng)我們要在線性表的順序存儲結(jié)構(gòu)上的第i個(gè)位置上插入一個(gè)元素時(shí),必須先將線性表的第i個(gè)元素之后的所有元素依次后移一個(gè)位置,以便騰空一個(gè)位置,再把新元素插入到 該位置。若要刪除第i個(gè)元素時(shí),也必須把第i個(gè)元素之后的所有元素前移一個(gè)位置。用鏈?zhǔn)酱鎯鉀Q此問題時(shí)可以采用循環(huán)鏈表4)注意問題:順序存儲和鏈?zhǔn)酱鎯?shí)現(xiàn)此算法時(shí)計(jì)算出列位置的不同

6、方法,人員出列后所做操作的區(qū)別。4. 一元稀疏多項(xiàng)式簡單的計(jì)算器(實(shí)驗(yàn)類型:綜合型)1)問題描述:用線性表表示一元稀疏多項(xiàng)式,設(shè)計(jì)一個(gè)一元多項(xiàng)式運(yùn)算器2)實(shí)驗(yàn)要求:采用單鏈表存儲結(jié)構(gòu)一元稀疏多項(xiàng)式輸入并建立多項(xiàng)式輸出多項(xiàng)式實(shí)現(xiàn)多項(xiàng)式加、減運(yùn)算3)實(shí)現(xiàn)提示:以兩個(gè)多項(xiàng)式相加為例結(jié)果多項(xiàng)式另存掃描兩個(gè)相加多項(xiàng)式,若都未檢測完:若當(dāng)前被檢測項(xiàng)指數(shù)相等,系數(shù)相加,若結(jié)果未變成0,則將結(jié)果插入到結(jié)果多項(xiàng)式。若當(dāng)前被檢測項(xiàng)指數(shù)不等,則將指數(shù)較小者插入到結(jié)果多項(xiàng)式。若有一個(gè)多項(xiàng)式已檢測完,則將另一個(gè)多項(xiàng)式剩余部分直接連接到結(jié)果多項(xiàng)式。5. 長整數(shù)(任意長度)四則運(yùn)算演示程序(實(shí)驗(yàn)類型:綜合型)1)問題描述:

7、設(shè)計(jì)一個(gè)實(shí)現(xiàn)任意長的整數(shù)進(jìn)行加法運(yùn)算的演示程序2)實(shí)驗(yàn)要求:利用雙向循環(huán)鏈表實(shí)現(xiàn)長整數(shù)的存儲,給各結(jié)點(diǎn)含一個(gè)整型變量。任何整型變量的的圍是-(215-1 ) (215-1 )。輸入和輸出形式:按照中國對長整數(shù)的表示習(xí)慣,每四位一組,組間用逗號隔開。3)實(shí)現(xiàn)提示:每個(gè)結(jié)點(diǎn)中可以存放的最大整數(shù)為215-1=32767,才能保證兩數(shù)相加不會溢出。但若這樣存,即相當(dāng)于按 32768進(jìn)制數(shù)存,在十進(jìn)制數(shù)與 32768進(jìn)制數(shù)之間的轉(zhuǎn)換十分不方便。故可以在 每個(gè)結(jié)點(diǎn)中僅存十進(jìn)制數(shù)的4位,即不超過9999的非負(fù)整數(shù),整個(gè)鏈表視為萬進(jìn)制數(shù)。可以利用頭結(jié)點(diǎn)數(shù)據(jù)域的符號代表長整數(shù)的符號。用其絕對值表示元素結(jié)點(diǎn)的樹木

8、。相加過程中不要破壞兩個(gè)操作數(shù)鏈表。兩操作數(shù)的頭指針存于指針數(shù)組中是簡化程序結(jié)構(gòu)的一種方法。4)注意問題:不能給常整數(shù)位數(shù)規(guī)定上限。程序設(shè)計(jì)源代碼如下:第一題:#in elude <stdio.h>#in elude <stdlib.h>#in elude<iostream.h>typedef int ElemType;Illi元素類型typedef struct LNodeElemType data;struct LNode *n ext;LNode;typedef LNode *Lin kList;Lin kList head;Lin kList L;

9、Illi定義單鏈表頭指針 LLin kList L1;Lin kList L2;Lin kList L12;尾插入法建立單鏈表Lin kList Creatlist_L()llliiliLin kList L,p,r;int x;r=L=(L in kList)malloc(sizeof(LNode);L-> next=NULL;cin> >x;while(x!=O)p=(L in kList)malloc(sizeof(LNode);p_>data=x;p-> next=NULL;r->n ext=p;r=p;cin> >x;return L;

10、LinkList Show_L(LinkList L)Lin kList p2;p2=L;while(p2-> next!=NULL)cout<<p2->n ext->data<<"" p2=p2->n ext;return L;Lin kList Con tlist_L(Li nkList A,Li nkList B)Li nkList C,a,b,e,f;a=A->n ext;b=B->n ext;C=A;/C表的頭節(jié)點(diǎn)f=C=(Li nkList)malloc(sizeof(LNode);C-> nex

11、t=NULL;/建立空鏈表while(a)e=(L in kList)malloc(sizeof(LNode); e->data=a->data;e-> next=NULL;f->n ext=e;f=e;a=a->n ext;while(b)e=(L in kList)malloc(sizeof(LNode); e->data=b->data;e-> next=NULL;f->n ext=e;f=e;b=b->n ext;return C; void mai n()int choice;for(;)cout<<"

12、+ 進(jìn)入菜單 +:"<<e ndl; cout<<"1.建立單鏈表:"<<endl;cout<<"2.連接單鏈表:"<<endl;cout<<"3.輸出單鏈表:"<<endl;cout<<"0.程序結(jié)束:"<<endl;cout<<e ndl;cout<<"請選擇操作序號:"<<endl;cin> >choice;if(choice

13、=0)cout<<"成績結(jié)束,任意鍵退出!"<<endl;break;switch(choice)case 1:int choice1;cout<<"開始建立單鏈表 1:"<<endl;L仁 Creatlist_L();cout<<e ndl;cout<<"表 1 建立完畢!"<<endl;"<<e ndl;cout<<"是否繼續(xù)建立單鏈表2 ? "<<"n 1. 繼續(xù) 2.

14、返回cin> >choice1;if(choice1=1)cout<<"開始建立單鏈表 2"<<endl;L2=Creatlist_L();cout<<e ndl;cout<<"表 2 建立完畢!"<<endl;cout<<e ndl;cout<<"單鏈表建立完畢!!"<<endl;break;case 2:cout<<" 開始連接單鏈表 1, 2!"<<endl;L12=Co ntl

15、ist_L(L1 ,L 2);cout<<"asfsdfsagshdfhgdfhjdfhhdfhasdf'<<e ndl;break;case 3:int choice1;cout<<"請選擇輸出哪個(gè)表:"<<endl;cout<<"1.表 12. 表 23.聯(lián)立后的表 12 "<<endl;cin> >choice1;switch(choice1)case 1:cout<<"單鏈表 1 為:"<<endl;S

16、how_L(L1);cout<<e ndl;break;case 2:cout<<"單鏈表 2 為:"<<endl;Show_L(L2);cout<<e ndl;break;case 3:cout<<"聯(lián)立后的表12為:"<<endl;Show_L(L12);cout<<e ndl;break; break;第二題:#in clude <stdio.h>#in clude <stdlib.h>#in clude<iostream.h>#

17、defi ne Maxsize 100/表中元素的最大個(gè)數(shù)typedef int ElemType; /typedef struct listElemType dataMaxsize; / in t le ngth;/SqList;/int m=0;元素類型靜態(tài)線性表表的實(shí)際長度順序表的類型名SqList *creat_SqList(SqList *L) /L=(SqList *)malloc(sizeof(SqList); cout<<"請輸入線性表數(shù)據(jù):"<<endl;建立線性表,并輸入線性表元素for(m;m+)ElemType x;cin&g

18、t; >x;if(x=O) break;L->datam=x; L->le ngth=m; return L;SqList *all_SqList(SqList *L)cout<<"已建立的線性表為:"<<endl;for(i nt i=0;i<L->le ngth;i+)cout<<L->datai<<""cout<<e ndl;return L;查詢元素函數(shù)"<<j+1<<"位!"<<e n

19、dl;int serch_SqList(SqList *L,i nt y) Illifor(i nt j=O;j<L->le ngth;j+)if(L->dataj=y)cout<<"表中含有此數(shù)據(jù),位于表中第return 1;break;else if(j=L->le ngth-1)cout<<"表中沒有此數(shù)據(jù)!"<<endl;break;elsecon ti nue;void judje_SqList(SqList *L)Illi判斷是否對稱函數(shù)if(m%2=0)lllll線性表元素個(gè)數(shù)為偶數(shù)個(gè)cou

20、t<<"中心元素為"<<L->datam/2<<endl;for(i nt k=0;k<=m/2+1;k+)if(k=m/2+1)cout<<"*該線性表對稱!*"<<endl;break;else if(L->datak=L->datam-1-k)con ti nue;elsecout<<" *該線性表不是對稱的!*"<<e ndl;break;else lllllllllllll線性表元素個(gè)數(shù)為奇數(shù)個(gè)cout<<

21、"中心元素為"<<L->dataml2<<endl;for(i nt t=0;t<=ml2+1;t+)if(t=ml2+1)cout<<"*該線性表對稱!*"<<endl;break;else if(L->datat=L->datam-1-t)con ti nue;elsecout<<" *該線性表不是對稱的!*"<<e ndl;break;int mai n()SqList *L1;int choice;for(;)cout<<

22、;"+ 主菜單 +"<<e ndl;cout<<"1.新建線性表;"<<endl;cout<<"2.遍歷線性表;"<<endl;cout<<"3.查找表中元素;"<<endl;cout<<"4.判斷是否對稱;"<<endl;cout<<"0.退出程序;"<<endl;cout<<e ndl;cout<<"請輸入操

23、作序號:"<<endl;cin> >choice;if(choice=0) break;switch(choice)case 1:L1=creat_SqList(L1);cout<<"線性表長度為:"<<m<<endl;break;case 2:cout<<"開始遍歷線性表:"<<endl;all_SqList(L1);break;case 3:int y;cout<<"請輸入要查找的元素:"<<endl;cin

24、87;y;serch_SqList(L1,y);break;case 4:cout<<"正在檢測是否對稱!"<<endl;judje_SqList(L1);break;return 0;第三題:#in clude <stdio.h>#in clude <stdlib.h>#in clude<iostream.h># define Maxsize 50 /元素最大容量typedef int ElemType; /元素類型typedef struct listElemType num Maxsize;ElemType

25、codeMaxsize; in t le ngth;/表的實(shí)際長度順序表的類型名Juserfu L;/定義一個(gè)順序表Lint j=0;/圍坐的總?cè)藬?shù)Juserfu *creat_Juserfu(Juserfu *L)/L=(Juserfu *)malloc(sizeof(Juserfu);cout<<"請分別輸入每個(gè)人的序號和密碼:"<<endl;for(j;j+)建立線性表,并輸入線性表元素ElemType m,s; /定義密碼cin> >s»m;if(m=0) break;L_>nu mj=s;L->codej=

26、m;L->le ngth=j;return L;Juserfu *output_Juserfu(Juserfu *L)/int x_num=O;int x_code;cout<<"請輸入初始密碼:"<<endl;cin>> x_code;for(j;j>0;j-)輸出出列者的序列Juserfu;/x_nu m=(x_ nu m+x_code-1)%j;"<<e ndl;cout<<x_num<<"出歹U者為"<<L->numx_num<&

27、lt;"號!x_code=L->codex_ nu m;for(x_ num;x_nu m<j;x_ nu m+)L->numx_num =L->numx_nu m+1;L->codex_ nu m=L->codex_ nu m+1;return L;void mai n()int s;Juserfu *L1;cout<<"請輸入每位圍坐者的密碼!"<<endl;L1=creat_Juserfu(L1);cout<<"共圍坐人數(shù)為:"<<L1->lengt

28、h<<endl;cout<<"密碼分別為:"<<endl;for(i nt i=0;i<j;i+)cout<<L1->numi<<" "<<L1->codei<<""output_Juserfu(L1);第四題:#in clude <stdio.h>#in clude <stdlib.h> #in clude<iostream.h>typedef struct PolyNode系數(shù)float coe

29、f;/float exp; /指數(shù)PolyNode *n ext;/指針域PolyNode;typedef PolyNode *Po lyn omial;Polynomial A;/定義多項(xiàng)式APolyno mial creat_Poly()Pol yno mial L,p,r;float x_coef;float x_exp;r=L=(Po lyno mial)malloc(sizeof(PolyNode);L-> next=NULL;cout<<"請依次輸入多項(xiàng)式的系數(shù)和指數(shù)(0,0為輸入結(jié)束):"<<endl;cin>> x_

30、coef»x_exp;while(x_coef!=0 && x_exp!=0)p=(Po lyno mial)malloc(sizeof(PolyNode);p->coef=x_coef;p->exp=x_exp;p-> next=NULL;r->n ext=p;r=p;cin>> x_coef>>x_exp;return L;Polyno mial show_Poly(Po lyno mial L)Polyno mial p1;p1=L;while(p1-> next!=NULL)cout<<p1-

31、>n ext->coef<<"X"<<p1- >n ext->exp<<" +" p1=p1- >n ext;cout<<e ndl;return L;Poly nomial add_Poly(Poly nomial A,Poly nomial B)Pol yno mial C,D;Poly nomial p1,p2,p3;float sum;p1=A->n ext;p2=B->n ext;C=(Poly nomial)malloc(sizeof(PolyNode)

32、;p3=C;p3-> next=NULL;while(p1 &&p2)if(p1_>exp=p2_>exp)sum=p1->coef+p2->coef;if(sum!=0)D=(Poly nomial)malloc(sizeof(PolyNode);D->coef=sum;D->exp=p1->exp;D-> next=NULL;p3-> next=D;p3=D;p1=p1- >n ext;p2=p2->n ext;else if(p1->exp<p2->exp)D=(Poly nomia

33、l)malloc(sizeof(PolyNode);D->coef=p1->coef;D_>exp=p1_>exp;D-> next=NULL;p3-> next=D;p3=D;p1=p1- >n ext;elseD=(Poly nomial)malloc(sizeof(PolyNode);D->coef=p2->coef;D_>exp=p2_>exp;D-> next=NULL;p3-> next=D;p3=D;p2=p2->n ext;while(p1) / 多項(xiàng)式A沒有處理完D=(Poly nomial)

34、malloc(sizeof(PolyNode);D->coef=p1->coef;D->exp=p1->exp;D-> next=NULL;p3-> next=D;p3=D;p1=p1- >n ext; while(p2) / 多項(xiàng)式B沒有處理完D=(Poly no mial)malloc(sizeof(PolyNode);D->coef=p2->coef;D_>exp=p2_>exp;D-> next=NULL;p3-> next=D;p3=D;p2=p2->n ext;return C;void mai n

35、()Poly no mial A;Polyno mial B;Poly nomial C;cout<<"開始建立多項(xiàng)式 A:"<<endl;A=creat_Poly();cout<<"多項(xiàng)式 A 為:"<<endl;show_Poly(A);cout<<"開始建立多項(xiàng)式 B:"<<endl;B=creat_Poly();cout<<"多項(xiàng)式 B 為:"<<endl;show_Poly(B);C=add_Poly(A,B);cout<<"相加之后得到的多項(xiàng)式C為:"<<endl;show_Poly(C);第五題:#in clude<stdio.h>#in clude<stdlib.h>#in clude<iostream.h> typedef struct Nodeint data;Node* next;Node* front;Node;typedef Node *Operati on;Operatio n creat()Operati on L;Operati on p1,p2;L=(

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論