版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验六 查找【实验项目】:完成二叉树的基本运算,从而了解其基本特征,基本运算算法一、实验目的1. 掌握查找的含义。2. 掌握基本查找操作的算法与实现。3. 掌握二叉排序树查找的算法与实现。4. 掌握Hash表查找的算法与实现。二、实验要求(本次实验要求上交)【题目】-验证型实验1. 建立一个线性表,对表中数据元素存放的先后次序没有任何要求。输入待查数据元素的关键字进行查找。(为了简化算法,数据元素只含一个整型量关键字字段,数据元素的其余数据部分忽略不考虑。)顺序查找的基本思想及程序实现(参考代码见文件夹6-1)对于给定的关键字k,从表的一端开始,逐个进行数据元素的关键字和给定值的比较,若当前扫
2、描到的结点关键字与k相等则查找成功;若扫描结束后,仍未找到关键字等于k的节点,则查找失败。 建立一个顺序表,数据元素从下标为1的单元开始放入,下标为0的单元起监视哨作用,将待查的关键字存入下标为0的单元,顺序表从后向前查找,若直到下标为0时才找到关键字则说明查找失败;若不到下标为0时就找到关键字,则查找成功。2. 查找表的存储结构为有序表,即表中记录按关键字大小排序存放。输入待查数据元素的关键字进行查找。(为了简化算法,记录只含一个整型量关键字字段,记录的其余数据部分略不考虑。程序要求对整型量关键字数据的输入按从小到大排序输入。)折半查找的基本思想及程序实现:(参考代码见文件夹6-1)设查找表
3、中的元素存放在数组r中,数据元素的下标范围为low,high,要查找的关键字值为key,中间元素的下标为mid=(low+high)2 (向下取整),令key与rmid的关键字比较:若key=rmid.key,查找成功,下标为m的记录即为所求,返回mid。若key<rmid.key,所要找的记录只能在左半部分记录中,再对左半部分使用折半查找法继续进行查找,搜索区间缩小了一半。若key>rmid.key,所要找的记录只能在右半部分记录中,再对右半部分使用折半查找法继续进行查找,搜索区间缩小了一半。 重复上述过程,直到找到查找表中某一个数据元素的关键字的值等于给定的值key说明查找成功
4、;或者出现low的值大于high的情况,说明查找不成功。建立一个有序表,数据元素从下标为1的单元开始放入。实现查找算法时,首先将low赋值为l,high等于最后一个数据元素的下标,然后将给定的关键字的值与查找区间low,high中间的数据元素的关键字比较, 实现查找过程。3. 编程实现二叉排序树的创建、查找、插入、输出等算法。二叉排序树基本思想及程序实现(参考代码见文件夹6-1)二叉排序树就是指将原来已有的数据根据大小构成一棵二叉树,二叉树中的所有结点数据满足一定的大小关系,所有的左子树中的结点均比根结点小,所有的右子树的结点均比根结点大。 二叉排序树查找是指按照二叉排序树中结点的关系进行查找
5、,查找关键字首先同根结点进行比较,如果相等则查找成功;如果比根结点小,则在左子树中查找;如果比根结点大,则在右子树中进行查找。这种查找方法可以快速缩小查找范围,大大减少查找关键字的比较次数,从而提高查找效率。 算法的关键过程实际上就是二叉排序树的创建和查找两个步骤。 首先分析二叉排序树的创建运算,由于二叉排序树中的所有结点都有一个大小关系,因此,每个结点必须在二叉排序树中寻找其合适的位置。创建二叉排序树的第一步就是创建一个根结点,第二步就是将其他结点不断插入到二叉排序树中的合适位置。二叉排序树进行结点插入时,首先要为被插入结点寻找合适的插入位置。这个过程实际上就是一个关键值不断的比较的过程。第
6、一次比较是与二叉排序树的根结点比较,如果比根结点的关键值小,则插入到他的左子树中;如果比根结点的关键值大,则插入到它的右子树中。在子树中重复这样过程,直到找到合适的位置为止。二叉排序树的查找运算实际上同二叉排序树的创建运算是一致的。区别在于,创建过程中要为二叉排序树中没有位置的关键字建立结点,而查找过程中,只是在二叉排序树中查找是否等于查找关键字值的结点存在,不管有还是没有,它都不会创建一个新的结点。【题目2】(注意:该程序将作为平时成绩的一部分计入期末总分,请认真完成。另外:请独立完成,在批改过程中若发现是抄袭的,相同版本第二份及其以上做不合格处理)编程实现一个开放式的高校本科招生最低录取分
7、数线的查询系统,供师生和家长查询。高校自愿放入该校的信息,可能随时有高校加入。要求实现的查询功能有:查询等于用户给定分数的高校;查询大于(或小于)用户给定分数的高校;查询最低录取分数线在用户给定的分数段中的高校。该实验主要的功能是查找,查找表为高校最低录取分数信息的集合。根据题意可知,该查找表中的元素个数可能随时增减,所以它是一个动态查找表,可采用树状结构保存。为了提高查询速度,可建立二叉排序树并在二叉排序树中实现查找。第一个要求可以直接利用一般的二叉排序树的查找算法实现。第二个要求可以利用比较二叉排序树根结点的关键字值和给定的分数实现,若前者大于或等于后者,根结点及其右子树中的结点全部满足要
8、求,再在根结点的左子树中查找;否则只在根结点的右子树中查找即可。第三个要求可以利用比较二叉排序树根结点的关键字值和给定的分数段实现,若前者在给定的分数段中,根结点就满足要求,则在根结点的左、右子树中继续查找即可:若前者给定的分数段的左侧,只在根结点的右子树中查找即可;若前者在给定的分数段的右侧,只根节点的左子树中查找即可。请将源程序附录于此:/文件名:shiayn6.cpp#include<stdio.h>#include<windows.h>#include<stdlib.h>#define TF 1#define EFALSE 0typedef stru
9、ct name /学校名称char Schoolname10,SchoolNum5;struct name *next;SchoolList;typedef struct /定义学校结构体int PassMark;SchoolList A;PassMark_Info;typedef struct coder /定义录取分数PassMark_Info data;struct coder *lchild,*rchild;Btree,*QBtree;void con(int x, int y)/用于循环选择操作 COORD c; c.X=x-1; c.Y=y-1; /* 保存文件 */void H_
10、(QBtree bt,FILE *fp)if(bt!=NULL) H_(bt->lchild,fp); fprintf(fp,"%st%st%dt",bt->data.A.SchoolNum,bt->data.A.Schoolname,bt->data.PassMark); H_(bt->rchild,fp);int Save(QBtree bt)FILE *fp;if(fp=fopen("passmark","rb")=NULL) printf("t"); return 0;else
11、 H_(bt,fp);fclose(fp);return TF;void Print(QBtree bt)SchoolList *p=&(bt->data.A);while(p) printf("%10st%10st%10dn",p->SchoolNum,p->Schoolname,bt->data.PassMark); p=p->next;void InOrder(QBtree bt,int PassMark,int PassMark_,int k)if(bt!=NULL) InOrder(bt->lchild,PassMark
12、,PassMark_,k); if(k=1&&bt->data.PassMark<=PassMark)|(k=2&&bt->data.PassMark>=PassMark)|(k=0&&PassMark<=bt->data.PassMark&&bt->data.PassMark<=PassMark_) Print(bt); InOrder(bt->rchild,PassMark,PassMark_,k);Btree* Search(QBtree bt,int PassMark)
13、if(bt=NULL)|(bt->data.PassMark=PassMark) return bt;else if(bt->data.PassMark>PassMark) return Search(bt->lchild,PassMark);else return Search(bt->rchild,PassMark);Btree* Bt_Insert(QBtree *bt,FILE *fp)Btree *p,*pre,*q;q=(Btree *)malloc(sizeof(Btree);if(q!=NULL) if(fp=NULL) puts("请输
14、入高校名称、学校代码和最低录取分数线:"); scanf("%s%s%d",q->data.A.Schoolname,q->data.A.SchoolNum,&q->data.PassMark); else fscanf(fp,"%st%st%dt",q->data.A.SchoolNum,q->data.A.Schoolname,&q->data.PassMark); q->lchild=q->rchild=NULL; q->data.A.next=NULL;if(*bt=
15、NULL) *bt=q;return *bt;p=*bt;while(p!=NULL) pre=p; if(p->data.PassMark>q->data.PassMark) p=p->lchild; else p=p->rchild;if(pre->data.PassMark>q->data.PassMark) pre->lchild=q;else if(pre->data.PassMark<q->data.PassMark) pre->rchild=q;else pre->data.A.next=&
16、;(q->data.A);return q;/写入学校信息int Read(QBtree *bt)FILE *fp;if(fp=fopen("passmark","rb")=NULL) printf("tFALSE"); return 0;else while(!feof(fp) Bt_Insert(bt,fp); fclose(fp); return 1;void help()printf("nt1:如果您是高校工作者请选择”4“填写学校招收信息。 ");printf("nt2:如果您是家长或者学
17、生请选择查询信息1-3要请查询。");printf("nnt谢谢您的配合!nn"); system("pause");int Menu()int i;system("cls");printf(" t 高校最低录取分数线查询系统菜单nn");printf(" t(请先输入一个学校方便测试)nn");printf("t1:按考生分数查询 2:按分数线查询n");printf("t3:按分数段查询 4:添加高校信息n");printf("t5
18、:操作规则 6:退出n");printf(" nt 请输入你想要的查询操作所对应的数字:");for(int j=0;) scanf("%d",&i); getchar(); if(i<1|i>6) puts(" 数据不合法!请重新选择操作项(16): "); con(40,10); continue; else return i;void main()int i,j;QBtree temp,bt=NULL;Read(&bt);while(1) i=Menu(); switch(i) case 1
19、: printf("输入你的成绩:"); scanf("%d",&i); temp=Search(bt,i); if(temp=NULL) printf("没有满足查询的学校信息有可能是未有学校入驻或者您的分数线低于查找要求n,建议选择2或3方式查找!"); system("pause"); else printf("有以下高校满足查询 %d 分:n 高校代码t 高校名称t最低录取线n",i); Print(temp); system("pause"); break; case 2: printf("输入分数线:"); scanf("%d",&i); printf("1:录取线在%d分以下的高校n 2:录取线在%d分以上的高校:n",i,i); scanf("%d",&j); while(j>2|j<1) printf("输入错误,请重新选择:&quo
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 课题申报参考:教育元宇宙的应用伦理研究
- 2025年严于修身学习心得体会(5篇)
- 疫情防护2025年度企业员工培训与心理咨询合同3篇
- 二零二五年度城市绿化养护劳务分包合同书4篇
- 二零二五年度城市住宅出售协议书(含装修及家具配置)4篇
- 二零二五年锅炉维修工程承包与环保验收协议3篇
- 2024手绘艺术作品拍卖合同协议3篇
- 安徽省二零二五年度住房租赁市场租赁纠纷处理合同
- 2025年护林员劳动合同书(含森林资源保护培训)3篇
- 2025版土地经营权租赁与农业产业扶贫合同3篇
- 消防产品目录(2025年修订本)
- 地方性分异规律下的植被演替课件高三地理二轮专题复习
- 光伏项目风险控制与安全方案
- 9.2提高防护能力教学设计 2024-2025学年统编版道德与法治七年级上册
- 催收培训制度
- ISO 22003-1:2022《食品安全-第 1 部分:食品安全管理体系 审核与认证机构要求》中文版(机翻)
- 2024年广东省高考地理真题(解析版)
- 2024高考物理广东卷押题模拟含解析
- 人教版五年级上册数学简便计算大全600题及答案
- GB/T 15945-1995电能质量电力系统频率允许偏差
- GB 32311-2015水电解制氢系统能效限定值及能效等级
评论
0/150
提交评论