1、数据结构实验七查找实验七 查找一、实验目的1. 掌握查找的不同方法,并能用高级语言实现查找算法; 2. 熟练掌握二叉排序树的构造和查找方法。3. 熟练掌握静态查找表及哈希表查找方法。二、实验内容设计一个读入一串整数,然后构造二叉排序树,进行查找。三、实验步骤1. 从空的二叉树开始,每输入一个结点数据,就建立一个新结点插入到当前已生成的二叉排序树中。2. 在二叉排序树中查找某一结点。3.用其它查找算法进行排序(课后自己做)。四、实现提示1. 定义结构typedef struct node int key; int other; struct node *lchild, *rchild; bstn
2、ode; void inorder ( t ) if (t!=Null) inorder(tlchild); printf(“%4d”, tkey); inorder(trchild); bstnode *insertbst(t, s) bstnode *s, *t; bstnode *f, *p; p=t; while(p!=Null) f=p; if (skey= =pkey) return t; if (skeypkey) p=plchild; else p=prchild; if(t= =Null) return s; if (skeyfkey) flchild=s; else frc
3、hild=s; return t; bstnode *creatord( ) bstnode *t, * s; int key; t=Null; scanf(“%d”,&key); while (key!=0) s=malloc(sizeof (bitree); skey=key; slchild=Null; srchild=Null; scanf(“%d”, &data); sother=data; t=insertbst(t, s); scanf(“%d”,&key); return t; 五、思考与提高1. 用其它的查找方法完成该算法。2.比较各种算法的时间及空间复杂度。六、完整参考程序
4、1.折半查找#include #include #define MAX 30 /定义有序查找表的最大长度typedef struct char elemMAX; /有序查找表 int length; /length指示当前有序查找表的长度SSTable;void initial(SSTable &); /初始化有序查找表int search(SSTable,int); /在有序查找表中查找元素void print(SSTable); /显示有序查找表中所有元素void main()SSTable ST; /ST为一有序查找表 int ch,loc,flag=1; char j; initial
5、(ST); /初始化有序查找表 while(flag) printf(请选择:n); printf(1.显示所有元素n); printf(2.查找一个元素n); printf(3.退出n); scanf( %c,&j); switch(j) case 1:print(ST); break; /显示所有元素 case 2:printf(请输入要查找的元素:); scanf(%d,&ch); /输入要查找的元素的关键字 loc=search(ST,ch); /查找 if(loc!=0) printf(该元素所在位置是:%dn,loc); /显示该元素位置 else printf(%d 不存在!n,
6、ch);/当前元素不存在 break; default:flag=0; printf(程序运行结束!按任意键退出!n);void initial(SSTable &v)/初始化有序查找表 int i; printf(请输入静态表的元素个数:); /输入有序查找表初始化时的长度 scanf(%d,&v.length); printf(请从小到大输入%d个元素(整形数):n,v.length); getchar(); for(i=1;i=v.length;i+) scanf(%d,&v.elemi); /从小到大输入有序查找表的各元素int search(SSTable v,int ch)/在有序
7、查找表中查找ch的位置,成功返回其位置,失败返回0 int low,high,mid; low=1;high=v.length; /置区间初值 while(lowch) high=mid-1; /继续在前半区间进行查找 else low=mid+1; /继续在后半区间进行查找 return 0; /找不到时,i为0void print(SSTable v) /显示当前有序查找表所有元素int i; for(i=1;i=v.length;i+) printf(%d ,v.elemi); printf(n);2.二叉排序树的建立与查找#include #include #include #incl
8、ude enum BOOLFalse,True;typedef struct BiTNode /定义二叉树节点结构char data; /为了方便,数据域只有关键字一项 struct BiTNode *lchild,*rchild; /左右孩子指针域BiTNode,*BiTree;BOOL SearchBST(BiTree,char,BiTree,BiTree&); /在二叉排序树中查找元素BOOL InsertBST(BiTree &,char); /在二叉排序树中插入元素 BOOL DeleteBST(BiTree &,char); /在二叉排序树中删除元素void Delete(BiTr
9、ee &); /删除二叉排序树的根结点void InorderBST(BiTree); /中序遍历二叉排序树,即从小到大显示各元素void main()BiTree T,p; char ch,keyword,j=y; BOOL temp; T=NULL; while(j!=n) printf(1.displayn); printf(2.searchn); printf(3.insertn); printf(4.deleten); printf(5.exitn); scanf( %c,&ch); /输入操作选项 switch(ch) case 1:if(!T) printf(The BST ha
10、s no elem.n); else InorderBST(T);printf(n); break; case 2:printf(Input the keyword of elem to be searched(a char):); scanf( %c,&keyword); /输入要查找元素的关键字 temp=SearchBST(T,keyword,NULL,p); if(!temp) printf(%c isnt existed!n,keyword); /没有找到 else printf(%c has been found!n,keyword); /成功找到 break; case 3:pr
11、intf(Input the keyword of elem to be inserted(a char):); scanf( %c,&keyword); /输入要插入元素的关键字 temp=InsertBST(T,keyword); if(!temp) printf(%c has been existed!n,keyword); /该元素已经存在 else printf(Sucess to inert %c!n,keyword); /成功插入 break; case 4:printf(Input the keyword of elem to be deleted(a char):); sca
12、nf( %c,&keyword); /输入要删除元素的关键字 temp=DeleteBST(T,keyword); if(!temp) printf(%c isnt existed!n,keyword); /该元素不存在 else printf(Sucess to delete %cn,keyword); /成功删除 break; default: j=n; printf(The program is over!nPress any key to shut off the window!n); getchar();getchar();void InorderBST(BiTree T)/以中序方
13、式遍历二叉排序树T,即从小到大显示二叉排序树的所有元素 if(T-lchild) InorderBST(T-lchild); printf(%2c,T-data); if(T-rchild) InorderBST(T-rchild);BOOL SearchBST(BiTree T,char key,BiTree f,BiTree &p)/在根指针T所指二叉排序树中递归的查找其关键字等于key的元素,若查找成功 /则指针p指向该数据元素,并返回True,否则指针指向查找路径上访问的最后一 /个结点并返回False,指针f指向T的双亲,其初始调用值为NULL BOOL tmp1,tmp2; tmp
14、1=tmp2=False; if(!T) p=f;return False; /查找不成功 else if(key=T-data) p=T;return True; /查找成功 else if(keydata) tmp1=SearchBST(T-lchild,key,T,p); /在左子树中继续查找 else tmp2=SearchBST(T-rchild,key,T,p); /在右子树中继续查找 if(tmp1|tmp2) return True; /若在子树中查找成功,向上级返回True else return False; /否则返回FalseBOOL InsertBST(BiTree
15、&T,char e)/当二叉排序树T中不存在元素e时,插入e并返回True,否则返回False BiTree p,s; if(!SearchBST(T,e,NULL,p) /查找不成功 s=(BiTree)malloc(sizeof(BiTNode); s-data=e; s-lchild=s-rchild=NULL; if(!p) T=s; /被插结点*s为新的根结点 else if(edata) p-lchild=s; /被插结点*s为左孩子 else p-rchild=s; /被插结点*s为右孩子 return True; /成功插入 else return False; /树中已存在关
16、键字为e的数据元素BOOL DeleteBST(BiTree &T,char key)/若二叉排序树T中存在关键字等于key的数据元素时,则删除该数据元素结点 /并返回True,否则返回False BOOL tmp1,tmp2; tmp1=tmp2=False; if(!T) return False; /不存在关键字等于key的数据元素 else if(key=T-data) Delete(T); return True; /找到关键字等于key的数据元素并删除它 else if(keydata) tmp1=DeleteBST(T-lchild,key); /继续在左子树中删除 else t
17、mp2=DeleteBST(T-rchild,key); /继续在右子树中删除 if(tmp1|tmp2) return True; /在子树中删除成功,返回True else return False; /不存在该元素 void Delete(BiTree &p)/在二叉排序树中删除结点p,并重接它的左或右子树 BiTree s,q; if(!p-rchild) /右子树空,只需重接它的左子树 q=p; p=p-lchild; free(q); else if(!p-lchild) /左子树空,只需重接它的右子树 q=p; p=p-rchild; free(q); else /左右子树均不空 q=p; s=p-lchild; while(s-rchild) q=s;s=s-rchild; /转左,然后向右走到尽头 p-data=s-data; /s指向被删结点的“前驱” if(q!=p) q-rchild=s-rchild; /重接*q的右子树 else q-lchild=s-lchild; /重接*q的左子树 free(s); (注:可编辑下载,若有不当之处,请指正,谢谢!)
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1