验证性实验五

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

k=search_bin(i,1,a.len,a); if (k == -1) printf("表中待查元素不存在\n\n"); else printf("表中待查元素存在,为第%d个元素\n",k); }
实验结果:
3、二叉排序树的查找、插入、删除等基本操作的实现 #include<stdio.h> #include<stdlib.h> #include<malloc.h> /******二叉排序树的数据结构********/ typedef struct Bstnode { int key; struct Bstnode *lchild,*rchild; }Bstnode,* Bstree; Bstree Create(); //创建二叉排序树 Bstree Insert(Bstree tree,int key); //插入 Bstree Search(Bstree tree,int key); //查找 void Traverse(Bstree tree); //遍历 Bstree Delete(Bstree tree,int key); //删除 /*********************创建二叉排序树**************/ Bstree Create() { int key; Bstree tree=NULL; //初始化空树 scanf("%d",&key); while(key!=0) { tree=Insert(tree,key); //逐个插入节点 scanf("%d",&key); } return tree; } /*******************插入*********************/ Bstree Insert(Bstree tree,int key) { Bstree p=tree;
Bstree s,f; while (p!=NULL) { f=p; if(key==p->key) return tree; if(key<p->key) p=p->lchild; else p=p->rchild; } s=(Bstree)malloc(sizeof(Bstnode)); s->key=key; s->lchild=NULL; s->rchild=NULL; if(tree==NULL) return s; //新节点为二叉排序树的根 if(key<f->key) f->lchild=s; else f->rchild=s; return tree; } /**************查找**************/ Bstree Search(Bstree tree,int key) { Bstree p=tree; int flag=0; while(p!=NULL) { if(p->key==key) { printf("查询到该节点!"); flag=1; return(p); break; } if (key<p->key) p=p->lchild; else p=p->rchild; } if(flag==0) { printf("查询不到关键字为%d的节点!",key); return NULL; } } /***************遍历*********************/ void Traverse(Bstree tree) { if(tree) { Traverse(tree->lchild); printf("%4d",tree->key); Traverse(tree->rchild); }
printf("|* 2.插入 *|\n"); printf("|* 3.查找 *|\n"); printf("|* 4.遍历 *|\n"); printf("|* 5.删除 *|\n"); printf("|* 6.退出 *|\n"); printf("********************************************\n"); while(select!=6) { printf("选择的功能:"); scanf("%d",&select); switch(select) { case 1: printf("请输入节点信息(0为结束符):\n"); tree=Create(); printf("\n"); break; case 2: printf("插入一个新的节点:"); scanf("%d",&key1);Insert(tree,key1); printf("插入后得序列为:\n"); Traverse(tree); printf("\n"); break; case 3: printf("输入查找的数据:"); scanf("%d",&key2); p=Search(tree,key2); printf("\n"); break; case 4: printf("遍历所得序列为:\n"); Traverse(tree); printf("\n"); break; case 5: printf("输入删除的数据:"); scanf("%d",&key3); tree=Delete(tree,key3); printf("删除后遍历所得序列:\n"); Traverse(tree); printf("\n"); break; case 6: printf("谢谢您的使用,再见!\n");flag=0;break; default:printf("输入错误,请重新输入\n");break; } } } 实验结果:
int len; }SSTABLE; int search_bin(KEYTYPE k, int low, int high,SSTABLE a) { /*有序表上二分法查找,递归算法*/ int mid; mid = -1; if(low <= high) /*low 表示当前表中第1个元素所在下标*/ /*high表示当前表中最后一个元素所在下标*/ { mid = (low +high)/2; /*mid表示当前表中中间一个元素所在下标*/ if(a.r[mid].key < k) mid = search_bin(k, mid + 1,high,a); /*二分法递归查找*/ else if(a.r[mid].key > k) mid = search_bin(k,low,high - 1,a); } return mid; /*mid = -1 查找不成功;mid!=-1 查找成功*/ } void main( ) { SSTABLE a; int i, j, k; printf("请输入有序表元素,元素为整型量(从小到大输入),用空 格分开,-100为结束标志 :\n"); j=0; k = 1; i = 0; scanf("%d",&i); while (i != -100) { j++; a.r[k].key = i; k++; scanf("%d",&i); }/*输入有序表元素*/ a.len = j; printf("\n有序表元素列表显示 :"); for (i = 1; i<=a.len; i++) printf("%d ",a.r[i]); printf("\n"); printf("\n输入待查元素关键字 : "); scanf("%d",&i);
验证性实验五Hale Waihona Puke Baidu
实验课程名:数据结构 专业班级: 学号: 姓名: 实验时间: 实验地点: K4-207
查找与排序
指导教师:
一、实验目的 1、掌握查找的不同方法,并能用高级语言实现查找算法。 2、熟练掌握顺序表的查找方法和有序顺序表的折半查找算法以及静态查找树的构造方法和 查找算法。 3、掌握二叉排序树的生成、插入、删除、输出运算。 4、掌握常用的排序方法,并能用高级语言实现排序算法。 5、深刻理解排序的定义和各种排序方法的特点,并能加以灵活运用。 6、了解各种方法的排序过程及依据的原则,并掌握各种排序方法的时间复杂度的分析方 法。 二、实验内容 下面是查找与排序的部分基本操作实现的算法,请同学们自己设计主函数和部分算法,调 用这些算法,完成下面的实验任务。 1、顺序表的顺序查找
实验结果:
2、有序顺序表的二分查找的算法
#include <stdio.h> #define KEYTYPE int #define MAXSIZE 100 typedef struct { KEYTYPE key; }SSELEMENT; typedef struct { SSELEMENT r[MAXSIZE];
int i, j, k; printf("请输入顺序表元素(整型量),用空格分开,0为结束标志 :"); j = 0; k = 1; i = 0; scanf("%d",&i); while (i!=0) { j++; a.r[k].key = i; k++; scanf("%d",&i); }/*输入顺序表元素*/ a.len = j; printf("\n顺序表元素列表显示 :"); for (i = 1; i<=a.len; i++) printf("%d ",a.r[i].key); printf("\n"); printf("\n输入待查元素关键字 : "); scanf("%d",&i); k=seq_search(i,a); if(k==0) printf("表中待查元素不存在\n"); else printf("表中待查元素存在,为第%d个元素\n",k); }
#include <stdio.h> #define KEYTYPE int #define MAXSIZE 100 typedef struct { KEYTYPE key; }SSELEMENT; typedef struct { SSELEMENT r[MAXSIZE]; int len; }SSTABLE; int seq_search(KEYTYPE k, SSTABLE st) {/*顺序表上查找元素*/ int j; j = st.len; /*顺序表元素个数*/ st.r[0].key = k; /*st->r[0]单元作为监视哨*/ while(st.r[j].key != k) j--; /*顺序表从后向前查找*/ return j; /*j=0, 找不到;j<>0 找到*/ } void main( ) { SSTABLE a;
} /***************删除*******************/ Bstree Delete(Bstree tree,int key) { Bstree p=tree; Bstree f,s,q; f=NULL; while(p) { //查找关键字为key的节点 if(p->key==key) break; f=p; if(p->key>key) p=p->lchild; else p=p->rchild; } if (p==NULL) return tree; if ((p->lchild==NULL)||(p->rchild==NULL)) { if(f==NULL) if(p->lchild==NULL) tree=p->rchild; else tree=p->lchild; else if (p->lchild==NULL) if(f->lchild==p) f->lchild=p->rchild; else f->rchild=p->rchild; else if(f->lchild==p) f->lchild=p->lchild; else f->lchild=p->lchild; free(p); } else { q=p;s=p->lchild; while(s->rchild) { q=s;s=s->rchild; } if(q==p) q->lchild=s->lchild; p->key=s->key; free(s); } return tree; } /*******************************************/ void main() { system("color 1E"); Bstree tree,p; int key1,key2,key3; int select,flag; printf("############################################\n"); printf("|* 欢迎您使用本系统 *|\n"); printf("|******************************************|\n"); printf("|* 1.创建二叉排序树 *|\n");
相关文档
最新文档