动态查找表实验报告材料
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
动态查找表实验报告
一.
1 、实验概要
实验项目名称: 抽象数据类型的实现
实验项目性质: 设计性实验
所属课程名称: 数据结构
实验计划学时: 6
2、实验目的
对某个具体的抽象数据类型,运用课程所学的知识和方法,设计合理的数据结构,并在此基础上实现该抽象数据类型的全部基本操作。通过本设计性实验,检验所学知识和能力,发现学习中存在的问题。进而达到熟练地运用本课程中的基础知识及技术的目的。
实验要求如下:
1.参加实验的学生应首先了解设计的任务,然后根据自己的基础和能力从中选择一题。一般来说,选择题目应以在规定的时间内能完成,并能得到应有的锻炼为原则。若学生对教材以外的相关题目较感兴趣,希望选作实验的题目时,应征得指导教师的认可,并写出明确的抽象数据类型定义及说明。
2. 实验前要作好充分准备,包括:理解实验要求,掌握辅助工具的使用,了解该抽象数据类型的定义及意义,以及其基本操作的算法并设计合理的存储结构。
3. 实验时严肃认真,要严格按照要求独立进行设计,不能随意更改。注意观察并记录各种错误现象,纠正错误,使程序满足预定的要求,实验记录应作为实验报告的一部分。
4. 实验后要及时总结,写出实验报告,并附所打印的问题解答、程序清单,所输入的数据及相应的运行结果。
所用软件环境或工具:DEV-C++5可视化编程环境.
3.动态查找表的抽象数据类型
ADT DynamicSearchTable {
数据对象D:D是具有相同特性的数据元素的集合。每个数据元素含有类型相同的关键字,可唯一
标识数据元素。
数据关系R:数据元素同属一个集合。
基本操作P:
InitDSTable(&DT);
操作结果:构造一个空的动态查找表DT。
DestroyDSTable(&DT);
初始条件:动态查找表DT存在;
操作结果:销毁动态查找表DT。
SearchDSTable(DT, key);
初始条件:动态查找表DT存在,key为和关键字类型相同的给定值;
操作结果:若DT中存在其关键字等于key的数据元素,则函数值为该元素的值或在表中的
位置,否
则为“空”。
InsertDSTable(&DT, e);
初始条件:动态查找表DT存在,e为待插入的数据元素;
操作结果:若DT中不存在其关键字等于e.key的数据元素,则插入e到DT。DeleteDSTable(&T, key);
初始条件:动态查找表DT存在,key为和关键字类型相同的给定值;
操作结果:若DT中存在其关键字等于key的数据元素,则删除之。
TraverseDSTable(DT, Visit());
初始条件:动态查找表DT存在,Visit是对结点操作的应用函数;
操作结果:按某种次序对DT的每个结点调用函数visit()一次且至多一次。一旦visit()失败,则
操作失败。
} ADT DynamicSearchTable
二.动态查找表的特点
二叉排序树是一种动态树表,其特点是,树的结构通常不是一资生成的,面是在查找过程中,当树中不存在关键字等于给定值的结点时再进行插入。新插入的结点一定是一个新添加的叶子结点,并且是查找不成功时查找路径上访问的最后一个结点的左孩子或右孩子结点。
三.算法设计
#include
#include
#include
#include
#include
typedef struct ElemType{
int key;
}ElemType;
typedef struct bitnode{ //二叉树的二叉链表存储表示
ElemType data;
struct bitnode *lchild,*rchild; //左右孩子指针
int length;
}bitnode,*bitree;
bitree Search(bitree T,ElemType e,bitree f,bitree &p)//在二叉排序树中查找数据
{
if(!T)
{
p=f;
return NULL;
} //查找不成功
else if(T->data.key==e.key)
{
p=T;return T;
} //查找成功
else if(T->data.key>e.key)
return Search(T->lchild,e,T,p);
else
return Search(T->rchild,e,T,p);
}//在二叉排序树中查找数据
void Insert(bitree &T,ElemType e) //在二叉排序树中插入数据{
bitree p,s;
if (!Search(T,e,NULL,p))//查找不成功
{
s=(bitree)malloc(sizeof(bitnode));
s->data=e;
s->lchild=s->rchild=NULL;
if (!p) T=s; //被插入结点*s为新的根结点
else if (e.key
p->lchild=s; //被插结点*s为左孩子
else
p->rchild=s; //被插结点*s为右孩子
return ;
}
else return ;
}
void Init(bitree &T)//构造一个动态查找表T
{ int x;
int i;
int n;
ElemType e;
printf("请输入结点个数: ");
scanf("%d",&x);
for(i=1;i<=x;i++)
{
printf("第%d个结点数据值:",i);
scanf("%d",&n);
e.key=n;