版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
...wd......wd......wd...實驗一線性表的鏈?zhǔn)酱鎯?gòu)造實驗?zāi)康模?.掌握線性表的鏈?zhǔn)酱鎯?gòu)造。2.熟練地利用鏈?zhǔn)酱鎯?gòu)造實現(xiàn)線性表的基本操作。3.能熟練地掌握鏈?zhǔn)酱鎯?gòu)造中算法的實現(xiàn)。二、實驗內(nèi)容:1.用頭插法或尾插法建設(shè)帶頭結(jié)點的單鏈表。2.實現(xiàn)單鏈表上的插入、刪除、查找、修改、計數(shù)、輸出等基本操作。三、實驗要求:1.根據(jù)實驗內(nèi)容編寫程序,上機調(diào)試、得出正確的運行程序。2.寫出實驗報告〔包括源程序和運行結(jié)果〕。四、實驗學(xué)時:2學(xué)時五、實驗步驟:1.進(jìn)入編程環(huán)境,建設(shè)一新文件;2.參考以下相關(guān)內(nèi)容,編寫程序,觀察并分析輸出結(jié)果。①定義單鏈表的數(shù)據(jù)類型,然后將頭插法和尾插法、插入、刪除、查找、修改、計數(shù)、輸出等基本操作都定義成子函數(shù)的形式,最后在主函數(shù)中調(diào)用它,并將每一種操作前后的結(jié)果輸出,以查看每一種操作的效果。②局部參考程序//單鏈表的建設(shè)(頭插法),插入,刪除,查找、修改、計數(shù)、輸出#include<iostream.h>#defineelemtypeintstructlink{elemtypedata;//元素類型link*next;//指針類型,存放下一個元素地址};//頭插法建設(shè)帶頭結(jié)點的單鏈表link*hcreat(){links,p;elemtypei;cout<<〞輸入多個結(jié)點數(shù)值(用空格分隔),為0時算法完畢〞;cin>>i;p=newlink;p->next=NULL;while(i)//當(dāng)輸入的數(shù)據(jù)不為0時,循環(huán)建單鏈表{s=newlink;s->data=i;s->next=p->next;p->next=s;cin>>i;}returnp;}//輸出單鏈表voidprint(1ink*head){1ink*p;p=head->next;while(p->next!=NULL){cout<<p->data<<〞->〞;//輸出表中非最后一個元素p=p->next;}cout<<p->data;//輸出表中最后一個元素cout<<endl;}∥在單鏈表head中查找值為x的結(jié)點Link*Locate(1ink*head,elemtypex){Link*p;p=head->next;while((p!=NULL)&&(p->data!=x))p=p->next;returnp;}//在head為頭指針的單鏈表中,刪除值為x的結(jié)點voiddeletel(1ink*head,elemtypex){1ink*p,*q;q=head;p=head->next;while((p!=NULL)&&(p->data!=x)){q=p;p=p->next;}If(p==NULL)cout<<“要刪除的結(jié)點不存在〞;elseq->next=p->next;delete(p);}}//在頭指針head所指的單鏈表中,在值為x的結(jié)點之后插入值為y的結(jié)點voidinsert(1ink*head,elemtypex,elemtypey){link*p,*s;s=newlink;s->data=y;if(head->next==NULL)//鏈表為空{(diào)head->next=s;s->next=NULL:}p=Locate(head,x);//調(diào)用查找算法‘if(p==NULL)cout<<〞插入位置非法〞:else(s->next=p->next;p->next=s;}}//將單鏈表p中所有值為x的元素修改成yvoidchange(1ink*p,elemtypex,elemtypey){link*q;q=p->next;while(q!=NULL){if(q->data==x)q->data=y;q=q->next;}}voidcount(1ink*h)//統(tǒng)計單鏈表中結(jié)點個數(shù){1ink*p;intn=0;p=h->next;while(p!=NULL){n++;p=p->next;}returnn;}voidmain(){intn;elemtypex,y;link*p,*q;p=hcreat();//頭插法建設(shè)鏈表print(p);//輸出剛建設(shè)的單鏈表cout<<〞請輸入要刪除的元素〞;cin>>y;deletel(p,y);print(p);//輸出刪除后的結(jié)果cout<<〞請輸入插入位置的元素值(將待插元素插入到它的后面)〞;cin>>x;cout<<〞請輸入待插元素值〞;cin>>y;insert(p,x,y);print(p);//輸出插入后的結(jié)果cout<<〞請輸入要修改前、后的元素值〞;cin>>x>>y;change(p,x,y);print(p);cout<<〞請輸入要查找的元素值〞;cin>>x;q=Locate(p,x);if(q==NULL)cout<<x<<〞不在表中,找不到!〞<<endl;elsecout<<x<<〞在表中,已找到!〞<<endl;n=count(p);cout<<〞鏈表中結(jié)點個數(shù)為:〞<<n<<endl:}//單鏈表的建設(shè)(尾插法)、插入、刪除、查找、修改、計數(shù)、輸出#include<iostream.h>#defineelemtypeintstructlink{elemtypedata;//元素類型link*next;//指針類型,存放下-個元素地址};//尾插法建設(shè)帶頭結(jié)點的單鏈表link*rcreat(){link*s,*p,*r;elemtypei;cout<<〞輸入多個結(jié)點數(shù)值(用空格分隔),為0時算法完畢〞;cin>>i;p=r=newlink;p->next=NULL;while(i){s=newlink;s->data=i;r->next=s;r=s;cin>>i;}r->next=NULL;returnp;}//輸出單鏈表voidprint(1ink*head){link*p;p=head->next;while(p->next!=NULL){cout<<p->data<<"->〞;//輸出表中非最后一個元素p=p->next;)cout<<p->data;//輸出表中最后一個元素cout<<endl;}link*Locate(1ink*head,intx)∥在單鏈表中查找第x個結(jié)點{link*p;p=head;intj=0;while((p!=NULL)&&(j<x)){p=p->next;j++;}returnp;}voiddeleteI(1ink*head,elemtypex)//在head為頭指針的單鏈表中,刪除值為x的結(jié)點{link*p,*q;q=head;p=head->next;while((p!=NULL)&&(p->data!=x)){q=p;p=p->next;)if(p==NULL)cout<<〞要刪除的結(jié)點不存在“;else{q->next=p->next;delete(p);}}voidinsert(1ink*head,intx,elemtypey)//在頭指針head所指單鏈表中,在第x個結(jié)點之后插入值為y的結(jié)點{link*p,*s;s=newlink;s->data=y;if(head->next==NULL)//鏈表為空{(diào)head->next=s;s->next=NULL:}p=Locate(head,x);//調(diào)用查找算法if(p==NULL)cout<<〞插入位置非法〞;else{s->next=p->next;p->next=s;}}voidchange(1ink*p,elemtypex,elemtypey){∥將單鏈表P中所有值為x的元素改成值為ylink*q;q=p->next;while(q!=NULL){if(q->data==x)q->data=y;q=q->next;}}voidcount(1ink*h)//統(tǒng)計單鏈表中結(jié)點個數(shù)(1ink*p;intn=0;p=h->next;while(p!=NULL){n++;p=p->next;}retumn;}voidmain(){intn;linkp,q;p=rcreat();//尾插法建設(shè)鏈表print(p);//輸出剛建設(shè)的單鏈表cout<<〞請輸入要刪除的元素〞;cin>>y;deletel(p,y);print(p);//輸出刪除后的結(jié)果cout<<〞請輸入插入位置〞;cin>>x;cout<<〞請輸入待插元素值〞;cin>>y;insert(p,x,y);print(p);//輸出插入后的結(jié)果cout<<〞請輸入修改前、后的元素值〞;cin>>x>>y;change(p,x,y);print(p);cout<<“請輸入要查找的元素值〞;cin>>x;q=Locate(p,x);if(q==NULL)cout<<x<<〞不在表中,找不到!〞<<endl;elsecout<<x<<〞在表中,已找到!〞<<endl;n=count(p);cout<<〞鏈表中結(jié)點個數(shù)為:〞<<n<endl;}六、選作實驗試設(shè)計一元多項式相加〔鏈?zhǔn)酱鎯Α车募臃ㄟ\算。A〔X〕=7+3X+9X8+5X9B〔X〕=8X+22X7-9X81.建設(shè)一元多項式;2.輸出相應(yīng)的一元多項式;3.相加操作的實現(xiàn)。實驗二循環(huán)鏈表的操作實驗?zāi)康模和ㄟ^本實驗中循環(huán)鏈表和雙向鏈表的使用,使學(xué)生進(jìn)一步熟練掌握鏈表的操作方式。二、實驗內(nèi)容:本次實驗可以從以下兩個實驗中任選一個:1.建設(shè)一個單循環(huán)鏈表并實現(xiàn)單循環(huán)鏈表上的逆置。所謂鏈表的逆置運算(或稱為逆轉(zhuǎn)運算)是指在不增加新結(jié)點的前提下,依次改變數(shù)據(jù)元素的邏輯關(guān)系,使得線性表(al,a2,a3,…,an)成為(an,…,a3,a2,a1)。2.構(gòu)建一個雙向鏈表,實現(xiàn)插入、查找和刪除操作。三、實驗要求:1.根據(jù)實驗內(nèi)容編寫程序,上機調(diào)試、得出正確的運行程序。2.寫出實驗報告〔包括源程序和運行結(jié)果〕。四、實驗學(xué)時:2學(xué)時五、實驗步驟:1.進(jìn)入編程環(huán)境,建設(shè)一新文件;2.參考以下相關(guān)內(nèi)容,編寫程序,觀察并分析輸出結(jié)果。①建設(shè)一個帶頭結(jié)點的單循環(huán)鏈表,從頭到尾掃描單鏈表L,把p作為活動指針,沿著鏈表向前移動,q作為p前趨結(jié)點,r作為q的前趨結(jié)點。其中,q的next值為r;r的初值置為head。②雙向鏈表的構(gòu)造與單鏈表一樣,至于它的插入與刪除運算比單鏈表復(fù)雜,插入運算需要4步操作,刪除運算需要2步操作,注意語句的次序,不要任意交換位置,以免不能正確插入或刪除結(jié)點。③局部參考程序//循環(huán)鏈表∥頭文件h1.h的內(nèi)容#defineNULL0#include<stdio.h>#include<malloc.h>typedefstructnode{intnum;structnode*next;}linklist;∥以下是主程序#include〞h1.h〞∥輸出循環(huán)鏈表的信息voidoutput(linklist*head){linklist*p;p=head->next;while(p!=head){printf(〞%d〞,p->num);p=p->next;}printf(〞\n〞);}//建設(shè)單循環(huán)鏈表Linklist*creat(intn){intk;linklist*head,*r,*p;p=(linklist*)malloc(sizeof(linklist));head=p;r=p;p->next=p;for(k=1;k<=n;k++){p=(linklist*)malloc(sizeof(linklist));p->num=k;r->next=p;r=p;}p->next=head;return(head);}∥逆置函數(shù)linklist*invert(linklist*head){Linklist*p,*q,*r;p=head->next;q=head;while(p!=head){r=q;q=p;p=p->next;q->next=r;}head->next=q;return(head);}voidmain(){intn;Linklist*head;printf(“輸入所建設(shè)的循環(huán)鏈表的結(jié)點個數(shù):\n〞);scanf(“%d〞,&n);head=creat(n);printf(〞輸出建設(shè)的單循環(huán)鏈表:\n〞);output(head);printf(〞現(xiàn)在進(jìn)展逆置!\n〞);head=invert(head);printf(〞輸出進(jìn)展逆置運算后的單循環(huán)鏈表的結(jié)點信息!\n〞);output(head);}//雙向鏈表參考程序//以下是頭文件hh.h的內(nèi)容#include<stdio.h>#include<malloc.h>typedefstructdupnode{intdata;structdupnode*next,*prior;}dulinklist;//以下是主程序的內(nèi)容#include〞hh.h〞//create函數(shù)用來構(gòu)建雙向鏈表dulinklist*create(){dulinklist*head,*p,*r;inti,n;head=(dulinklist*)malloc(sizeof(dulinklist));head->next=NULL;head->prior=NULL;r=head;printf(“請輸入所建雙向鏈表中結(jié)點的個數(shù):\n〞);scanf(“%d〞,&n);for(i=l;i<=n;i++){p=(dulinklist*)malloc(sizeof(dulinklist));printf(〞輸入結(jié)點的值:\n〞);scanf(〞%d’,&p->data);p->next=NULL;r->next=p;p->prior=r;r=r->next;}return(head);}//find函數(shù)用來實現(xiàn)在雙向鏈表中按序號查找某個結(jié)點的功能。voidfind(dulinklist*h){intk,i;dulinklist*p;p=h;i=0:printf(〞輸入要查找結(jié)點的序號:\n〞);scanf(〞%d〞,&k);while((p!=NULL)&&(i<k)){p=p->next;i++:}if(p){printf(〞所查到的結(jié)點的值為:\n〞);printf(〞%d\n〞,p->data);}elseprintf(〞沒找到該結(jié)點!\n〞);}//insdulist函數(shù)用來實現(xiàn)在雙向鏈表中按序號插入結(jié)點的功能dulinklist*insdulist(dulinklist*head,inti,intx){dulinklist*p,*s;intj;p=head;j=0;whi1e((p->next!=head)&&(j<i-1))//找到第i-1個結(jié)點{p=p->next;j++;}If(j==i-1){s=(dulinklist*)malloc(sizeof(dulinklist));s->data=x;s->prior=p;s->next=p->next;p->next->prior=s;p->next=s;}elseprintf(〞error\n〞);returnhead;}//deledulist函數(shù)實現(xiàn)在雙向鏈表中按序號刪除某個結(jié)點的功能dulinklist*deledulist(dulinklist*head,inti){dulinklist*p;intj;p=head;j=0while((p->next!=head)&&(j<i)){p=p->next;j++;}If(j==i){p->prior->next=p->next;p->next->prior=p->prior;free(p);}elseprintf(〞error\n〞);returnhead;}//output函數(shù)用來輸出整個雙向鏈表的結(jié)點值voidoutput(dulinklist*h){dulinklist*p;p=h->next;while(p!=NULL){printf(〞輸出該雙向鏈表的結(jié)點,分別為:\n〞);printf(〞%d\n〞,p->data);p=p->next;}}voidmain(){dulinklist*head;intflag=l,i,k,x;while(flag)//flag作為判斷循環(huán)的標(biāo)志位{printf(〞1.建設(shè)雙向鏈表\n〞);printf(〞2.查找某個結(jié)點\n〞);printf(〞3.插入一個結(jié)點\n〞);prtntf(〞4.刪除一個結(jié)點\n〞);printf(〞5.退出\n〞);printf(〞請輸入選擇:\n“);scanf(〞%d〞,&i);switch(i){case1:head=create0;break;case2:find(head);break;case3:printf(〞輸入待插的結(jié)點的序號及新插入結(jié)點的data值.\n〞);scanf(〞%d%d〞,&k,&x);head=insdulist(head,k,x);output(head);break;case4:printf(〞輸入要刪除的結(jié)點的序號.\n〞);scanf(〞%d,&k);head=deledulist(head,k);output(head);break;case5:flag=0;}}//while循環(huán)完畢}此程序不管是插入、查找還是刪除運算均是按序號的方式來處理,當(dāng)然也可改為按結(jié)點的值來作相應(yīng)的處理,試修改以上程序?qū)崿F(xiàn)按值操作的功能。六、選作實驗利用單循環(huán)鏈表存儲構(gòu)造,解決約瑟夫〔Josephus〕環(huán)問題。即:將編號是1,2,…,n(n>0)的n個人按照順時針方向圍坐一圈,每人持有一個正整數(shù)密碼。開場時任選一個正整數(shù)作為報數(shù)上限值m,從某個人開場順時針方向自1開場順序報數(shù),報到m時停頓報數(shù),報m的人出列,將他的密碼作為新的m值,從他在順時針方向的下一個人開場重新從1報數(shù),如此下去,直到所有的人全部出列為止。令n最大值取30。設(shè)計一個程序,求出出列順序,并輸出結(jié)果。實驗三樹形構(gòu)造實驗?zāi)康模?.掌握二叉樹的數(shù)據(jù)類型描述及二叉樹的特性。2.掌握二叉樹的鏈?zhǔn)酱鎯?gòu)造(二叉鏈表)的建設(shè)算法。3.掌握二叉鏈表上二叉樹的基本運算的實現(xiàn)。二、實驗內(nèi)容:從以下1、2和3、4中各選擇一項內(nèi)容1.用遞歸實現(xiàn)二叉樹的先序、中序、后序3種遍歷。2.用非遞歸實現(xiàn)二叉樹的先序、中序、后序3種遍歷。3.實現(xiàn)二叉樹的層次遍歷。4.將一棵二叉樹的所有左右子樹進(jìn)展交換。實驗要求:1.根據(jù)實驗內(nèi)容編程,上機調(diào)試、得出正確的運行程序。2.寫出實驗報告〔包括源程序和運行結(jié)果〕。四、實驗學(xué)時:4學(xué)時五、實驗步驟:1.進(jìn)入編程環(huán)境,建設(shè)一新文件;2.參考以下相關(guān)內(nèi)容,編寫程序,觀察并分析輸出結(jié)果。將建設(shè)二叉樹及先序、中序、后序3種遍歷算法都寫成子函數(shù),然后分別在主函數(shù)中調(diào)用它,但在建設(shè)二又樹中,必須把二叉樹看成完全二叉樹的形式。假設(shè)不是完全二叉樹,那么在輸入數(shù)據(jù)時,用虛結(jié)點(不存在)表示(本算法中,用“,〞號代替)。用非遞歸法實現(xiàn)二叉樹的遍歷非遞歸算法中,必須設(shè)置堆棧,可以直接用一維數(shù)組來代替棧,但必須另外設(shè)置棧頂指針。③實現(xiàn)二叉樹的層次遍歷用一個一維數(shù)組代替隊列,實現(xiàn)二叉樹的層次遍歷。④將一棵二叉樹的所有左右子樹進(jìn)展交換。本算法只要增加一個實現(xiàn)二叉樹左右子樹交換的子函數(shù)即可。為了便于查看,在主函數(shù)將交換前后的三種遍歷效果,分別輸出。以下為局部參考程序://遞歸實現(xiàn)二叉樹的3種遍歷#include<iostream.h>typedefcharelemtype;structbitree{定義二叉樹數(shù)據(jù)類型elemtypedata;//結(jié)點信息bitree*lchild,*rchild;//左右孩子};bitree*create()//建設(shè)二叉鏈表{bitree*root,*s,*q[100];//q為隊列,最大空間為100intfront=l,rear=0;//隊列頭、尾指針charch;root=NULL;cout<<〞請輸入結(jié)點值(‘,’為虛結(jié)點,‘#’完畢):〞<<endl;cin>>ch;while(ch!=’#’){s==NULL;if(ch!=’,’){s=newbitree;s->data=ch;s->lchild=NULL;s->rchild=NULL;}rear++;q[rear]=s;//進(jìn)隊if(rear==1)root=s;else{if((s!=NULL)&&(q[front]!=NULL)){if(rear%2==0)q[front]->lchild=s;elseq[front]->rchid=s;}if(rear%2==1)front++;//出隊}cin>>ch;}returnroot:}voidpreorder(bitree*root)//先序遍歷{bitree*p;p=root;if(p!=NULL){cout<<p->data<<〞〞;preorder(p->lchild);preorder(p->rchild);}}voidinorderl(bitree*root)//中序遍歷{bitree*p;p=root;if(p!=NULL){inorder(p->lchild);cout<<p->data<<“〞;inorder(p->rchild);}}voidpostorder(bitree*root)//后序遍歷{bitree*p;p=root;if(p!=NULL){postorder(p->lchild);postorder(p->rchild);cout<<p->data<<“〞;}}voidmain(){bitree*root;root=create();//建設(shè)二叉鏈表cout<<〞先序遍歷的結(jié)果〞<<endl;preorder(root);cout<<endl;cout<<〞中序遍歷的結(jié)果〞<<endl;inorder(root);cout<<endl:cout<<〞后序遍歷的結(jié)果〞<<endl;postorder(root);cout<<endl;}//用非遞歸實現(xiàn)二叉樹的3種遍歷,局部遍歷程序如下:voidpreorderl(bitree*root)//先序遍歷{bitree*p,*s[100];//s為堆棧inttop=0;//top為棧頂指針p=root;while((p!=NULL)||(top>0)){while(p!=NULL){cout<<p->data<<〞〞;s[++top]=p;//進(jìn)棧p=p->lchild;}p=s[top--];//退棧p=p->rchild;}}voidinorderl(bitree*root)//中序遍歷{bitree*p,*s[100];inttop=0;p=root;while((p!=NULL)Il(top>O)){while(p!=NULL){s[++top]=p;p=p->lchild;}{p=s[top--];cout<<p->data<<“〞;p=p->rchild;}}}voidpostorderl(bitree*root)//后序遍歷(bitree*p*sl[100];ints2[100],top=0,b;p=root;do{while(p!=NULL){s1[top]=p;s2[top++]=0;p=p->lchild;)if(top>0)(b=s2[--top];p=s1[top];if(b==0){sl[top]=p;s2[top++]=l;p=p->rchild;}else{cout<<p->data<<〞〞;p=NULL;}}}while(top>0);}//建設(shè)二叉鏈表參考前述程序//按照層次遍歷二叉鏈表#include<iostream.h>typedefcharelemtype;structbitree{elemtypedata;//結(jié)點信息bitree*lchild,*rchild;//左右孩子};//按層次遍歷二叉樹(建設(shè)二叉鏈表同前)voidlorder(bitree*t){bitreeq[100],*p;//q代表隊列intf,r;//f,r類似于隊列頭、尾指針q[1]=t;f=r=l;cout<<〞按層次遍歷二叉樹的結(jié)果為:〞;whileif<==r){p=q[f];f++;//出隊cout<<p->data<<〞〞;if(P->lchild!=NULL){r++;q[r]=p->lchild;}//入隊ifp->rchild!=NULLl.{r++;q[r]=p->rchild;}//入隊}cout<<endl;}voidmain(){bitree*t;t=create0;//建設(shè)二叉鏈表lorder(t);//:按層次遍歷二叉樹}//將二叉樹的左右子樹進(jìn)展交換voidleftOright(bitree*r){bitree*root=r;if(root!=NULL){leftOright(root->lchild);leftOright(root->rchild);bitree*t=root->lchild;root->lchild=root->rchild;root->rchild=t;}}//主函數(shù)voidmain(){bitree*root;root=create();//建設(shè)二叉鏈表cout<<endl<<endl<<〞左右子樹交換前的遍歷結(jié)果〞<<endl;cout<<〞先序遍歷的結(jié)果〞<<endl;preorder(root);cout<<endl;cout<<〞中序遍歷的結(jié)果〞<<endl;inorder(root);cout<<endl:cout<<〞后序遍歷的結(jié)果〞<<endl;postorder(root);cout<<endl;}leftTOright(root);cout<<endl<<endl<<〞左右子樹交換后的遍歷結(jié)果〞<<endl;cout<<〞先序遍歷的結(jié)果〞<<endl;preorder(root);cout<<endl;cout<<〞中序遍歷的結(jié)果〞<<endl;inorder(root);cout<<endl;cout<<〞后序遍歷的結(jié)果〞<<endl;postorder(root);cout<<endl;}六、選作實驗1.給定權(quán)值5,29,7,8,14,23,3,11,建設(shè)哈夫曼樹,輸出哈夫曼編碼。2.對上述給定的哈夫曼樹及得到的哈夫曼編碼,試輸入一串二進(jìn)制編碼,輸出它的哈夫曼譯碼。算法提示:將建設(shè)哈夫曼樹、實現(xiàn)哈夫曼編、哈夫曼譯碼都定義成子函數(shù)的形式,然后在主函數(shù)調(diào)用它們。建設(shè)哈夫曼樹時,將哈夫曼樹的構(gòu)造定義為一個構(gòu)造型的一維數(shù)組,每個元素含有四項:雙親、左孩子、右孩子。給定的權(quán)值可以從鍵盤輸入,要輸出所建設(shè)的哈夫曼樹,只要輸出哈夫曼樹的一維數(shù)組中全部元素即可。要實現(xiàn)哈夫曼編碼,只要在所建設(shè)的哈夫曼樹上進(jìn)展二進(jìn)制編碼:往左走,編碼為0,往右走,編碼為1,然后將從根結(jié)點到樹葉中所有0、l排列起來,那么得到該樹葉的哈夫曼編碼。哈夫曼編碼可以用一個構(gòu)造型的一維數(shù)組保存,每個元素包含:編碼、編碼的開場位置、編碼所對應(yīng)的字符等3項。哈夫曼譯碼,就是將輸入的編碼復(fù)原成對應(yīng)的字符。實驗四圖的遍歷操作實驗?zāi)康模?.掌握圖的含義。2.掌握用鄰接矩陣和鄰接表的方法描述圖的存儲構(gòu)造。3.理解并掌握深度優(yōu)先遍歷和廣度優(yōu)先遍歷的存儲構(gòu)造。二、實驗內(nèi)容:從以下1、2和3、4中各選擇一項內(nèi)容1.建設(shè)無向圖的鄰接矩陣,并實現(xiàn)插入、刪除邊的功能。2.建設(shè)有向圖的鄰接表,并實現(xiàn)插入、刪除邊的功能。3.建設(shè)一個包含6個結(jié)點的圖,并實現(xiàn)該圖的深度優(yōu)先搜索遍歷。4.建設(shè)一個包含6個結(jié)點的圖,并實現(xiàn)該圖的廣度優(yōu)先搜索遍歷。三、實驗要求:1.根據(jù)實驗內(nèi)容編程,上機調(diào)試、得出正確的運行程序。2.寫出實驗報告〔包括源程序和運行結(jié)果〕。四、實驗學(xué)時:4學(xué)時五、實驗步驟:1.進(jìn)入編程環(huán)境,建設(shè)一新文件;2.參考以下相關(guān)內(nèi)容,編寫程序,觀察并分析輸出結(jié)果。內(nèi)容1的知識要點:圖由一個非空的頂點的集合和一個描述頂點之間關(guān)系(邊)的集合組成。它可以定義為G=(V,E)。其中,G表示一個圖,V是圖G中頂點的集合,E是圖G中邊的集合。圖是一種復(fù)雜的數(shù)據(jù)構(gòu)造。對于實際問題,需要根據(jù)具體圖的構(gòu)造特點以及所要實施的操作,選擇建設(shè)適宜的存儲構(gòu)造。圖的存儲構(gòu)造包括鄰接矩陣和鄰接表。鄰接矩陣:用一維數(shù)據(jù)組存儲圖中頂點的信息,用矩陣表示圖中各頂點之間的相鄰關(guān)系。它屬于靜態(tài)存儲方法。鄰接表:鄰接表存儲方法是一種順序存儲與鏈?zhǔn)酱鎯ο嘟Y(jié)合的存儲方法。順序存儲局部用來保存圖中頂點的信息,鏈?zhǔn)酱鎯植坑脕肀4鎴D中邊的信息。//鄰接矩陣的存儲構(gòu)造typedefstruct{intvertex;}node;typedefstruct{intadj;}arc;typedefstruct{nodenode[maxnode];arcarcs[maxnode][maxnode];}graph;//實現(xiàn)插入、刪除邊的操作voidins_arc(graph*g,intv,intw){g->arcs[v][w].adj=l;return;}voiddel_arc(graph*g,intv,intw){g->arc[v][w].adj=0;retum;}//內(nèi)容1參考程序#definemaxnode40#definenull0#include<stdio.h>typedefstructst_arc{intadjvex;intweight;structst_arc*nextrac;}arcnode;typedefstruct{intvertex;structst_arc*firstarc;}vernode;typedefvernodeadjlist[maxnode];voiddel_arc(vernodeg[],intv,intw)//刪除從頂點v到頂點w的邊{arcnode*rl,*r2;rl=g[v].frrstarc;r2=rl;while(r1!=null&&r1->adjvex!=w){r2=rl;rl=rl->nextarc;}if(rl==null){printf(〞noedgev-w.〞);return;}elseif(r1==r2)//當(dāng)只有一個邊結(jié)點時g[v].firstarc=r1->nextarc;elser2->nextarc=r1->nextarc;//有多個邊結(jié)點時rl=g[w].firstarc;r2=rl;while(r1!=null&&r1->adjvex!=v)//在以v為頭結(jié)點的鏈表中,刪除相應(yīng)的//邊結(jié)點{r2=rl;rl=rl->nextarc;}if(rl==null){printf(〞noedgev-w.〞);return;}elseif(r1==r2)g[w].firstarc=rl->nextarc;elser2->nextarc=r1->nextarc;}voidprint(vernodeg[],intn)//打印圖中各結(jié)點的構(gòu)造{arcnode*q;inti;printf(〞adjacencylistofthegraph:\n〞);for(i=0;i<n;i++){printf(〞\t%d\t〞,i);printf(〞%d\t〞,g[i].vertex);q=g[i].firstarc;while(q!=null){printf(〞%d\t〞,q->adjvex);printf(〞%d\t〞,q->weight);q=q->nextarc;}printf(〞\n〞);}}main(){inti,j,n,k,w,v;arcnode*p,*q;adjlistg;printf(〞Inputnode:〞);//輸入圖中頂點個數(shù)scanf(〞%d〞,&n);for(k=0;k<n;k++)//輸入邊值和權(quán)值{printf(〞node%d=〞,k);scanf(“%d〞,&g[k].vertex);g[k].firstarc=null;//對順序存儲局部初始化}for(;;)//輸入各邊,并將對應(yīng)的邊結(jié)點插入到鏈表中{printf(〞Insertedgei-j,w:〞)scanf(〞%d〞,&i);scanf(〞%d〞,&j);scanf(〞%d〞,&w);if〔i==-1&&j==-1&&w=-1)break;q=(arcnode*)malloc(sizeof(arcnode));q->adjvex=j;q->weight=w;q->nextarc=g[i].firstarc;//頭指針指向新的邊結(jié)點g[i].firstarc=q;p=(arcnode*)malloc(sizeof(arcnode));p->nextarc=g[i].firstarc;g[i].firstarc=q;p=(arcnode*)malloc(sizeof(arcnode));p->adjvex=i;p->weight=w;p->nextarc=g[j].firstarc;g[j].firstarc=p;}print(g,n);printf(〞DeleteedgeV-w:〞);scanf(〞%d%d〞,&v,&w);del_arc(g,v,w);print(g,n);}內(nèi)容2的知識要點:構(gòu)造有向圖鏈接表與無向圖鏈接表的算法區(qū)別是:無向圖兩結(jié)點無向?qū)ε迹蚨徑颖碛幸欢ǖ膶ε夹?;有向圖兩結(jié)點間有向無對偶關(guān)系,因而建設(shè)鄰接表時應(yīng)根據(jù)輸入的頂點及邊的有向關(guān)系建設(shè)(當(dāng)箭頭方向離開結(jié)點為有關(guān),當(dāng)箭頭方向指向結(jié)點為無關(guān))。//內(nèi)容2的參考程序//有向圖鏈表的存儲構(gòu)造為:typedefstructst_arc{intaajvex;//存放依附于該邊的另一頂點在一維數(shù)組中的序號intweight;//存放和該邊有關(guān)的信息,如權(quán)值等structst_arc*nextarc;//依附于該頂點的下一個邊結(jié)點的指針}arcnode;typedefstruct{intvertex;//存放與頂點有關(guān)的信息structst_arc*firstarc;}vernode;//存儲頂點信息typedefvernodeadjlist[maxnode];//參考程序見內(nèi)容1內(nèi)容3的知識要點:深度優(yōu)先搜索遍歷圖的算法:首先訪問指定的起始頂點v0,從vo出發(fā),訪問vo的一個未被訪問過的鄰接頂點w1,再從w1出發(fā),訪問w1的一個未被訪問的頂點w2,然后從w2出發(fā),訪問w2的一個未被訪問的鄰接頂點w3,依此類推,直到一個所有鄰接點都被訪問過為止。圖采用鄰接表作存儲構(gòu)造,圖的深度優(yōu)先遍歷次序為①→②→④→⑤→⑥→③參考程序運行過程中,深度優(yōu)先遍歷時指針p的移動方向示意如圖下所示,圖中p1、p2、p3、p4、p5和p6為深度優(yōu)先遍歷圖的各結(jié)點時,指針p的移動次序。//內(nèi)容3的參考程序#definemaxnode40#definenull0#include<sddio.h>typedefstructst_arc//定義構(gòu)造體{intadivex;intweigh;structst_arc*nextarc;}arcnode;typedefstruct{intvertex;structst_arc*firstarc;}vernode;typedefvernodeadjlist[maxnode];voidtrave(adjlistg,intn)//采用鄰接表作存儲構(gòu)造的/深度優(yōu)先遍歷{inti,visited[maxnode];//數(shù)組visited標(biāo)志圖中的定點是否已被訪問voiddfs();for(i=0;i<n;i++)visited[i]=0;//數(shù)組初始化for(i=0;i<n;i++)if(visited[i]==0)dfs(g,i,visted);}voiddfs(adjlistg,intk,intvisited[])//從頂點k出發(fā),深度優(yōu)先遍歷圖g。{arcnode*p;intw;visited[k]=1;printf(%d,g[k],vertex);p=g[k],firstarc;while(p!=null){w=p->adjvex;if(visited[w]==0)dfs(g,w,visited);p=p->nextarc;}}main(){inti,j,n,k,v;arcnode*p,*q;adjlistg;printf(“Inputnode:〞);scanf(“%d〞,&n);for(k=0;k<n;k++)//構(gòu)造圖{printf(“node%d=〞,k);g[k].firstarc=null;}for(;;){printf(“Insertedgei-j:〞);scanf(“%d〞,&i);scanfi(“%d〞,&j);if(i==-1&&j==-1)break;q=(arcnode*)malloc(sizeof(arcnode));q->adjvex=j;q->nextarc=g[i].firstarc;g[i]firstarc=q;p=(arcnode*)malloc(sizeof(arcnode));p->adjvex=i;p->nextarc=g[i].firstarc;g[i]_firstarc=p;}printf(“dfs:〞);trave(g,n);//深度優(yōu)先遍歷圖。printf(“\n〞);}內(nèi)容4的知識要點:廣度優(yōu)先遍歷圖的算法:首先訪問指定的起始頂點v0,從v0出發(fā),訪問v0的所有未被訪問的鄰接頂點w1,w2,…,wk,然后再依次從w1,w2,…,wk出發(fā),訪問所有未被訪問過的鄰接頂點,依此類推,直到圖中所有未被訪問過的鄰接頂點都被訪問過為止。根據(jù)廣度優(yōu)點遍歷的規(guī)那么,在其算法實現(xiàn)中,借助一個隊列g(shù)-queue來存放已被訪問過的頂點。從指定頂點開場,每訪問一個頂點,就將它入隊并排在隊尾,然后從隊頭取出一個頂點,訪問該頂點的所有未被訪問的鄰接點,依此類推,直至隊列為空且圖中結(jié)點均被訪問過為止。圖的廣度優(yōu)先遍歷次序為:①→②→③→④→⑤→⑥參考程序運行過程中,廣度優(yōu)先搜索時指針p的移動示意如以以下圖所示,圖中片p1、p2、p3、p4、p5和p6為廣度優(yōu)先遍歷圖的各結(jié)點指針p的移動次序。//內(nèi)容4的參考程序#definemaxnode40#definenull0#include<sddio.h>typedefstructst_arc//定義構(gòu)造體{intadivex;intweigh;structst_arc*nextarc;}arcnode;typedefstruct{intvertex;structst_arc*firstarc;}vernode;typedefvernodeadjlist[maxnode];typedefstruct{intqueue[maxnode];intfront;intrear;}qqtype;voidintiate(qqtype*q)//初始化隊列{q->front=-1;q->rear=-1;}intenter(qqtype*q,intx)//將X入隊{if(q->rear==maxnode-1)return(-1);else{q->rear++;q->queue[q->rear]=x;return(0);}}intdelete(qqtype*q)//出隊{if(q->front==q->rear)return(null);else{q->front++;return(q->queue[q->front]);}}intemtype(qqtype*q){if(q->front==q->rear)return(-1);return(0);}voidbfs(adjlistg,intk,intvisited[])//從頂點k出發(fā)進(jìn)展廣度優(yōu)先遍歷{arcnode*p;intw;intiate(g);visited[k]=1;//訪問點從k開場,并把它入隊。printf(“%d〞,g[p->adjvex].vertex);enter(g,k);while(emptye(g)==0){w=delete(g);p=g[w].firstarc;while(p!=null){if(visited[p->adjves]==0){printf(“%d〞,g[p->adjvex].verte);visited[p->adjvex]=1;enter(g.p->adjvex);}p=p->nextarc;}}}voidtrave(adjlistg,intn)//圖采用鄰接表存儲的廣度優(yōu)先遍歷{inti,visited[maxnode];//數(shù)組visited標(biāo)志圖中的定點是否已被訪問。for(i=0;i<n;i++)visited[i]=0;//數(shù)組初始化for(i=0;i<n;i++)if(visited[i]==0)bfs(g,i,visted);}main(){inti,j,n,k,v;arcnode*p,*q;adjlistg;printf(“Inputnode:〞);scanf(“%d〞,&n);for(k=0;k<n;k++)//構(gòu)造圖{printf(“node%d=〞,k);scanf(“%d〞,&g[k].vertex);g[k].firstarc=null;}for(;;){printf(“Insertedgei-j:〞);scanf(“%d〞,&i);scanfi(“%d〞,&j);if(i==-1&&j==-1)break;q=(arcnode*)malloc(sizeof(arcnode));q->adjvex=j;q->nextarc=g[i].firstarc;g[i]firstarc=q;p=(arcnode*)malloc(sizeof(arcnode));p->adjvex=i;p->nextarc=g[i].firstarc;g[i]_firstarc=p;}printf(“bfs:〞);trave(g,n);//廣度優(yōu)先遍歷圖。printf(“\n〞);}六、選作實驗假設(shè)有n個城市,要實現(xiàn)n個城市之間都能互相通信和構(gòu)造n個城市之間的通信網(wǎng),使工程總造價最低。設(shè)計一個能滿足要求的最低造價方案。實驗五查找實驗?zāi)康模?.掌握查找的含義。2.掌握基本查找操作的算法與實現(xiàn)。3.掌握二叉排序樹查找的算法與實現(xiàn)。4.掌握Hash表查找的算法與實現(xiàn)。二、實驗內(nèi)容:從以下1、2和3、4中各選擇一項內(nèi)容1.建設(shè)一個線性表,對表中數(shù)據(jù)元素存放的先后次序沒有任何要求。輸入待查數(shù)據(jù)元素的關(guān)鍵字進(jìn)展查找?!矠榱撕喕惴?,數(shù)據(jù)元素只含一個整型量關(guān)鍵字字段,數(shù)據(jù)元素的其余數(shù)據(jù)局部忽略不考慮?!?.查找表的存儲構(gòu)造為有序表,即表中記錄按關(guān)鍵字大小排序存放。輸入待查數(shù)據(jù)元素的關(guān)鍵字進(jìn)展查找?!矠榱撕喕惴?,記錄只含一個整型量關(guān)鍵字字段,記錄的其余數(shù)據(jù)局部略不考慮。程序要求對整型量關(guān)鍵字?jǐn)?shù)據(jù)的輸入按從小到大排序輸入?!?.編程實現(xiàn)二叉排序樹的創(chuàng)立、查找、插入、輸出等算法。4.設(shè)哈希表長為20,用除留余數(shù)法構(gòu)造一個哈希函數(shù),以開放定址法中的線性探測再散列法作為解決沖突的方法,編程實現(xiàn)哈希表查找、插入和建設(shè)算法。三、實驗要求:1.根據(jù)實驗內(nèi)容編程,上機調(diào)試、得出正確的運行程序。2.寫出實驗報告〔包括源程序和運行結(jié)果〕。四、實驗學(xué)時:6學(xué)時五、實驗步驟:1.進(jìn)入編程環(huán)境,建設(shè)一新文件;2.參考以下相關(guān)內(nèi)容,編寫程序,觀察并分析輸出結(jié)果。順序查找的基本思想及程序?qū)崿F(xiàn)對于給定的關(guān)鍵字k,從表的一端開場,逐個進(jìn)展數(shù)據(jù)元素的關(guān)鍵字和給定值的比較,假設(shè)當(dāng)前掃描到的結(jié)點關(guān)鍵字與k相等那么查找成功;假設(shè)掃描完畢后,仍未找到關(guān)鍵字等于k的節(jié)點,那么查找失敗。建設(shè)一個順序表,數(shù)據(jù)元素從下標(biāo)為1的單元開場放入,下標(biāo)為0的單元起監(jiān)視哨作用,將待查的關(guān)鍵字存入下標(biāo)為0的單元,順序表從后向前查找,假設(shè)直到下標(biāo)為0時才找到關(guān)鍵字那么說明查找失??;假設(shè)不到下標(biāo)為0時就找到關(guān)鍵字,那么查找成功。//參考程序#include<stdio.h>#defineKEYTYPEint#defineMAXSIZE100typedefstruct{KEYTYPEkey;}SSELEMENT;typedefstruct{SSELEMENTr[MAXSIZE];intlen;}SSTABLE;intseq_search(KEYTYPEk,SSTABLE*st)//順序表查找元素{intj;j=st->len;//順序表元素個數(shù)st->r[0].key=k;//st->r[0]單元作為監(jiān)視哨while(st->r[j].key!=k)//順序表從后向前查找j--;returnj;//j=0,找不到,j≠0找到}main(){SSTABLEa;inti,j,k;printf(〞請輸入順序表元素,元素為整型量,用空格分開,-99為完畢標(biāo)志:〞);j=0;k=1;i=0;scanf(〞%d〞,&i);while(i!=-99){j++;a.r[k].key=i;k++;scanf(〞%d〞,&i);}a.1en=j;printf(〞\n順序表元素列表顯示:〞);for(i=1;i<=a.1en;i++)printf(〞%d〞,a.r[i].key);printf(“\n〞);printf(〞\n輸入待查元素關(guān)鍵字:〞);scanf(“%d〞,&i);k=seq_search(i,&a);if(k==0)printf(“表中待查元素不存在\n\n〞);elseprintf(“表中待查元素存在\n\n〞);}折半查找的基本思想及程序?qū)崿F(xiàn):設(shè)查找表中的元素存放在數(shù)組r中,數(shù)據(jù)元素的下標(biāo)范圍為[low,high],要查找的關(guān)鍵字值為key,中間元素的下標(biāo)為mid=(low+high)/2(向下取整),令key與r[mid]的關(guān)鍵字比較:假設(shè)key=r[mid].key,查找成功,下標(biāo)為m的記錄即為所求,返回mid。假設(shè)key<r[mid].key,所要找的記錄只能在左半局部記錄中,再對左半局部使用折半查找法繼續(xù)進(jìn)展查找,搜索區(qū)間縮小了一半。假設(shè)key>r[mid].key,所要找的記錄只能在右半局部記錄中,再對右半局部使用折半查找法繼續(xù)進(jìn)展查找,搜索區(qū)間縮小了一半。重復(fù)上述過程,直到找到查找表中某一個數(shù)據(jù)元素的關(guān)鍵字的值等于給定的值key說明查找成功;或者出現(xiàn)low的值大于high的情況,說明查找不成功。建設(shè)一個有序表,數(shù)據(jù)元素從下標(biāo)為1的單元開場放入。實現(xiàn)查找算法時,首先將low賦值為l,high等于最后一個數(shù)據(jù)元素的下標(biāo),然后將給定的關(guān)鍵字的值與查找區(qū)間[low,high]中間的數(shù)據(jù)元素的關(guān)鍵字比較,實現(xiàn)查找過程。//參考程序#include<stdio.h>#defineKEYTYPEjnt#defineMAXSIZE100typedefstruct{KEYTYPEkey;}SEELEMENT;typedefstruct{SSELEMENTr[MAXSIZE];intlen;}SSTABLE;intsearch_bin(KEYTYPEk,SSTABLE*st),//有序表上折半查找{intlow,high,mid;low=1;//low=l表示元素從下標(biāo)為1的單元放起high=st->len;//high=st->len表示最后一個元素的下標(biāo)while(1ow<=high)//low<=high為繼續(xù)查找的條件{mid=(1ow+high)/2;if(k==st->r[mid].key)//k==st->r[mid].key表示查找成功retummid;elseif(k<st->r[mid].key)//否那么繼續(xù)二分查找high=mid-l;elselow=mid+l;}return0;//查找不成功,返回0}main(){{SSTABLEa;inti,j,k;printf(“請輸入有序表元素,元素為整型量(從小到大輸入),用空格分開,-99為完畢標(biāo)志:〞);j=0;k=1;I=0;scanf(“%d〞,&i);while(i!=-99){j++;a.r[k].key=i;k++;scanf(“%d〞,&i);//輸入有序表元素}a.1en=j;printf(“\n有序表元素列表顯示:〞);for(i=l;i<=a.1en;i++)printf(“%d〞,a.r[i]);printf(“\n〞);pfintf(〞\n輸入待查元素關(guān)鍵字:〞);scanf[“%d〞,&i];k=search_bin(i,&a);if(k==0)printf("表中待查元素不存在\n\n");elseprintf(〞表中待查元素存在\n\n");}二叉排序樹基本思想及程序?qū)崿F(xiàn)二叉排序樹就是指將原來已有的數(shù)據(jù)根據(jù)大小構(gòu)成一棵二叉樹,二叉樹中的所有結(jié)點數(shù)據(jù)滿足一定的大小關(guān)系,所有的左子樹中的結(jié)點均比根結(jié)點小,所有的右子樹的結(jié)點均比根結(jié)點大。二叉排序樹查找是指按照二叉排序樹中結(jié)點的關(guān)系進(jìn)展查找,查找關(guān)鍵字首先同根結(jié)點進(jìn)展比較,如果相等那么查找成功;如果比根結(jié)點小,那么在左子樹中查找;如果比根結(jié)點大,那么在右子樹中進(jìn)展查找。這種查找方法可以快速縮小查找范圍,大大減少查找關(guān)鍵字的比較次數(shù),從而提高查找效率。算法的關(guān)鍵過程實際上就是二叉排序樹的創(chuàng)立和查找兩個步驟。首先分析二叉排序樹的創(chuàng)立運算,由于二叉排序樹中的所有結(jié)點都有一個大小關(guān)系,因此,每個結(jié)點必須在二叉排序樹中尋找其適宜的位置。創(chuàng)立二叉排序樹的第一步就是創(chuàng)立一個根結(jié)點,第二步就是將其他結(jié)點不斷插入到二叉排序樹中的適宜位置。二叉排序樹進(jìn)展結(jié)點插入時,首先要為被插入結(jié)點尋找適宜的插入位置。這個過程實際上就是一個關(guān)鍵值不斷的比較的過程。第一次比較是與二叉排序樹的根結(jié)點比較,如果比根結(jié)點的關(guān)鍵值小,那么插入到他的左子樹中;如果比根結(jié)點的關(guān)鍵值大,那么插入到它的右子樹中。在子樹中重復(fù)這樣過程,直到找到適宜的位置為止。二叉排序樹的查找運算實際上同二叉排序樹的創(chuàng)立運算是一致的。區(qū)別在于,創(chuàng)立過程中要為二叉排序樹中沒有位置的關(guān)鍵字建設(shè)結(jié)點,而查找過程中,只是在二叉排序樹中查找是否等于查找關(guān)鍵字值的結(jié)點存在,不管有還是沒有,它都不會創(chuàng)立一個新的結(jié)點。//參考程序#include<stdio.h>#include<malloc.h>#definenull0typedefintkeytype;//查找關(guān)鍵字為整型數(shù)據(jù)sturcBsnode//二叉排序樹結(jié)點類型{keytypedata;//數(shù)據(jù)域structBsnode*Lchild,*Rchild;//左右指針};typedefstructBsnodeBST;typedefstructBsnode*BSP;//BSP為二叉排序樹結(jié)點類型指針BSPcreateBst(keytypekey)//為關(guān)鍵字key創(chuàng)立一個二叉排序樹結(jié)點{BSPs;s=(BSP)malloc(sizeof(BST));s->data=key;s->Lchild=s->Rchild=null;return(s);}BSPBSTinsert(BSPT,BSPS)//將S指向的結(jié)點插入到T指向的二叉排序樹中{BSPq,p;if(T==null)return(S);else{p=T;q=null;while(p)//在二叉排序樹中為s結(jié)點尋找插入位置{q=p;if(s->data==p->data)//如果S結(jié)點與二叉排序樹中根結(jié)點的值相等,那么不插入{printf(“Theinputkey(%d)ishavein!〞,s->data);return(t);}if(s->data<p->date)//如果比根結(jié)點值小,那么在左子樹中尋找插入位置p=p->Lchild;else//否那么在右子樹中尋找插入位置p=p->Rchild;}if(s->data<q->data)q->Lchild=s;//作為左孩子插入elseq->Rchild=s;//作為右孩子插入return(t);}}voidsearch(BSPT,keytypex)//在二叉排序樹T中查找是否存在關(guān)鍵宇{BSPp;if(T==null){printf(“error\n〞);return;}else{p=Twhile(p){if(p->data==x)//如果根結(jié)點是查找的關(guān)鍵字,查找完畢{printf(“searchsuccess!\n〞);return;}elseif(x<p->-data)//如果小于根結(jié)點,那么在左于樹中查找p=p->Lchild;elsep=p->Rchild;//否那么,在右子樹中查找}if(!p)printf(〞%dnotexist!\n〞,x);}}voidBSTPrint(BSPT)//輸出二叉排序樹{if(T){BSTPrint(T->Lchild);printf(〞%d->〞,T->data);BSTPrint(T->Rchild);}}main(){BSPT,S;keytypekey;intselect=0,flag=l;T=null;while(flag)//主菜單{printf(〞1…CreateBsort_tree\n〞);printf(〞2…Insertkey\n〞);printf(〞3…Searchkey\n〞);printf(〞4…Quit\n〞);printf(〞Pleaseselect:\n〞);scanf(〞%d〞,&select);switch(select){casel://創(chuàng)立二叉排序樹{printf(〞PleaseinputkeytocreateBsort_Tree:\n〞);scanf(〞%d〞,&key);while(key!==0){S=createBst(key);T=BSTinsert(T,S);printf(〞continueinput!\n〞);scanf(“%d〞,&key);}printf(〞Bsort_Treeis:\n〞);BSTPrint(T);Printf(“\n\n〞);break;}case2://在二叉排序樹中插入關(guān)鍵字{printf(〞Pleaseinputkeywhichinserted:\n〞);scanf(“%d〞,&key);S=createBst(key);T=BSTinsert(T,S);printf(〞Bsort_Treeis:\n〞);BSTPrint(T);printf(〞\n\n〞);break;}case3://在二叉排序樹中查找關(guān)鍵字{printf(〞Pleaseinputkeywhichsearched:\n〞);scanf(“%d〞,&key);search(T,key);printf(〞\n\n);break;}case4://產(chǎn)退出{flag=0;break;}}}}哈希表查找基本思想及程序?qū)崿F(xiàn)哈希表查找是一種基于盡可能不通過比較操作而直接得到記錄的存儲位置的想法而提出的一種特殊查找技術(shù)。它的基本思想是通過記錄中的關(guān)鍵字的值key為自變量,通過某一種確定的函數(shù)h,計算出函數(shù)值h(key)作為存儲地址,將相應(yīng)關(guān)鍵字的記錄存儲到對應(yīng)的位置上。而在查找時仍需要用這個確定的函數(shù)h進(jìn)展計算,獲得所要查找的關(guān)鍵字所在記錄的存儲位置。除留余數(shù)法(DivisionMethod)是用關(guān)鍵字key除以某個正整數(shù)M,所得余數(shù)作為哈希地址的方法。對應(yīng)的哈希函數(shù)h(key)為h(key)=key%M,一般情況下M的取值為不大于表長的質(zhì)數(shù)。用開放定址法解決沖突,形成下一個地址的形式是Hi=(h(key)+di)%Mi=l,2,…,k(k≤m-1)式中,h(key)為哈希函數(shù);M為某個正整數(shù);di為增量序列。線性探測再散列是將開放定址法中的增量序列di設(shè)定為-系列從1開場一直到表長減l的整數(shù)序列:l,2,3,…,m-1〔m為表長)。算法的關(guān)鍵過程實際上就是Hash表的創(chuàng)立和查找兩個步驟。首先分析Hash表的創(chuàng)立運算:將由鍵盤輸入的關(guān)鍵字key作為自變量,通過除留余數(shù)法構(gòu)造哈希函數(shù)h,計算出函數(shù)值h(key)作為存儲地址,將該關(guān)鍵字存儲到對應(yīng)的位置上。如果產(chǎn)生沖突,那么采用線性探查法,從關(guān)鍵字的哈希地址開場向后掃描,直到找到空位置,將該關(guān)鍵字存儲在這個位置,插入成功;假設(shè)掃描到哈希表的最后仍沒有找到空位置,那么插入失敗。查找時仍利用除留余數(shù)法構(gòu)造哈希函數(shù)h,計算出函數(shù)值h(key)獲得所要查找的關(guān)鍵字所在記錄的存儲位置。假設(shè)存儲位置對應(yīng)的數(shù)據(jù)元素的值與查找關(guān)鍵字相等,那么查找成功,否那么,采用線性探查法,從關(guān)鍵字的哈希地址開場向后掃描,直到找到與關(guān)鍵字相等的數(shù)據(jù)元素,查找成功;假設(shè)掃描到哈希表的最后仍沒有找到與關(guān)鍵字相等的數(shù)據(jù)元素,那么查找失敗,不存在與關(guān)鍵字相等的數(shù)據(jù)元素。//參考程序#include<stdio.h>//哈希表長最大值#defineHM20#defineM19#defineFREE0//空閑標(biāo)記#defineSUCESS1//成功#defineUNSUCESS0//不成功typedefintkeytype;//keytype為整型typedefstruct//keytype型關(guān)鍵字key{keytypekey;intcn;
溫馨提示
- 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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東科學(xué)技術(shù)職業(yè)學(xué)院《數(shù)字電路基礎(chǔ)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東金融學(xué)院《酒店空間設(shè)計》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東行政職業(yè)學(xué)院《工程制圖與數(shù)字化表達(dá)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東環(huán)境保護(hù)工程職業(yè)學(xué)院《藝術(shù)概論(二)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東東軟學(xué)院《抗震與高層建筑結(jié)構(gòu)設(shè)計》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東創(chuàng)新科技職業(yè)學(xué)院《化工過程開發(fā)與設(shè)計》2023-2024學(xué)年第一學(xué)期期末試卷
- 《老字的其他用法》課件
- 《自發(fā)性氣胸的診治》課件
- 《線性代數(shù)課本》課件
- 廣東財經(jīng)大學(xué)《工程熱力學(xué)(二)》2023-2024學(xué)年第一學(xué)期期末試卷
- 2024年中國陶瓷碗盆市場調(diào)查研究報告
- ISO 56001-2024《創(chuàng)新管理體系-要求》專業(yè)解讀與應(yīng)用實踐指導(dǎo)材料之22:“8運行-8.1運行策劃和控制”(雷澤佳編制-2025B0)
- 2024-2030年中國硅肥行業(yè)規(guī)模分析及投資前景研究報告
- 電網(wǎng)行業(yè)工作匯報模板22
- 2024年度跨境電商平臺承包經(jīng)營合同3篇
- 2025年上半年人民日報社招聘應(yīng)屆高校畢業(yè)生85人筆試重點基礎(chǔ)提升(共500題)附帶答案詳解
- 神經(jīng)外科基礎(chǔ)護(hù)理課件
- 山東省臨沂市2023-2024學(xué)年高二上學(xué)期期末考試生物試題 含答案
- 2024-2025學(xué)年一年級數(shù)學(xué)上冊期末樂考非紙筆測試題(二 )(蘇教版2024秋)
- 辦公樓電氣改造施工方案
- 內(nèi)蒙古赤峰市2023-2024學(xué)年高一上學(xué)期期末考試物理試題(含答案)
評論
0/150
提交評論