免费预览已结束,剩余4页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据结构C+实验报告广西大学计电学院计网103班数据结构实验报告(四)姓名梁田班级计网103班学号1007300340指导教师李静滨日期2011/12/26实验名称查找算法比较实验目的:熟练掌握各种静态查找表的查找方法(顺序查找法、折半查找法、分块查找)的操作及实现。实验内容:对各种查找算法进行比较。要求:(1)任意输入1组50个有序数据;(2)对顺序查找、折半查找、分块查找的查找次数进行比较并输出比较结果。实验环境与设备: PC Windows7系统 Microsoft Visual C+ 6.0源程序代码:#include#includeusing namespace std;typedef int Key;typedef structKey key;Rec;typedef structint index;Key data;Index;templatevoid px(Telem a,int n)int min,i,j;Telem temp;for(i=0;in-1;i+) min=i;for(j=i+1;jn;j+)if(ajamin)min=j;temp=ai;ai=amin;amin=temp;/正向顺序查找int srch0(Rec r,int n,Key k,int &m)cout顺序查找n;m=0;int i(0);while(m+,(ri.key!=k)&(in)return(-1);elsereturn(i);/逆向顺序查找int srch1(Rec r,int n,Key k,int &m)m=0;int i(n);r-1.key=k;while(m+,ri.key!=k)i-;return(i);/折半查找int efsrch(Rec r,int n,Key k,int &m)m=0;cout二分查找n;int low,hig,mid;low=0;hig=n;while(m+,low=hig)mid=(low+hig)/2;if(k=rmid.key)return(mid);else if(krmid.key)hig=mid-1;elselow=mid+1;return(-1);/分块查找(二分查找)int idxsrch(Rec r,int n,Key k,int &g,int &h)cout分块查找n;g=0;h=0;int i;int l=(int)sqrt(n);int m=(n+l-1)/l;cout分块数: lendl;Index *ind;ind=new Indexl;for(i=1;i=l;i+)indi.index=i*m-1;indi.data=ri*m-1.key;i=1;while(g+,il)if(indi.datak)i+;elsebreak;int low,hig,mid;low=i*m-m;hig=i*m-1;while(h+,low=hig)mid=(low+hig)/2;if(k=rmid.key)return(mid);else if(krmid.key)hig=mid-1;elselow=mid+1;return(-1);void main()int n,num;int *a;coutn; a=new intn;int i,j,k,l,m,sx0,sx1,sx2,sx3,sx4;cout请输入n个数组元素:n;for(i=0;iai;px(a,n);Rec *r;r=new Recn;for(i=0;in;i+)ri.key=ai;for(i=0;in;i+)coutri.key ;num+;if(num%10=0)coutendl;coutendl;coutm;coutendl;/顺序查找i=srch0(r,n,m,sx0);j=srch1(r,n,m,sx1); if(i=-1)cout查找失败!n;else cout查找成功!n;cout正向查出的位置: i+1endl反向查出的位置: j+1endl;cout查找次数: 正向查找 sx0 次,反向查找 sx1 次,共 sx0+sx1 次nn;/折半查找k=efsrch(r,n,m,sx2);if(k=-1)cout查找失败!n;else cout查找成功!n; cout位置: k+1endl; cout查找次数: sx2 次nn;/分块查找l=idxsrch(r,n,m,sx3,sx4);if(l=-1)cout查找失败!n;elsecout查找成功!n;cout位置: l+1endlendl;cout查找次数: 调用索引表 sx3 次,调用顺序表 sx4 次,共 sx3+sx4 次nn;运行结果: 查找成功: 查找失败:实验分析:1、 顺序查找过程:从表中的最后一个记录开始,逐个进行记录的关键字与给定值进行比较,若某个记录的关键字与给定值相等,则查找成功,找到所查的记录;反之,若直到第一个记录,其关键字和给定值比较都不相等,则表明表中没有所查的记录,查找失败。2、 折半查找也称二分查找,其算法思路:首先,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。3、 分块查找又称索引顺序查找,它是顺序查找的一种改进方法。其方法描述:将n个数据元素按块有序划分为m块(m n)。每一块中的结点不必有序,但块与块之间必须按块有序;即第1块中任一元素的关键字都必须小于第2块中任一元素的关键字;而第2块中任一元素又都必须小于第
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 内蒙古自治区通辽市科左后旗甘旗卡第二高级中学2025-2026学年高二上化学期末检测模拟试题含解析
- 重庆三峡医药高等专科学校《建筑施工组织及BIM应用》2024-2025学年第一学期期末试卷
- 2025-2026学年上海市金山区金山中学物理高二第一学期期末教学质量检测试题含解析
- 疾病预防控制策略
- 河南省九师.商周联盟2025-2026学年生物高一第一学期期末达标检测试题含解析
- 血液透析并发症护理培训
- 艾滋病综合管理方案
- 精神科抑郁症患者心理疏导方法
- 眼科白内障手术后护理方案
- 康复医学科脊柱骨折康复护理方案
- 强国必须强军强军才能国安
- 实验室质量管理体系建立与运行课件
- 青少年药物滥用的预防和干预
- 插扣式脚手架施工方案
- 焊材抽检记录表
- 建设用地规划许可证审批表
- 国家开放大学《小城镇建设》形考任务1-4参考答案
- 咳嗽的诊断与治疗指南
- 车架设计手册
- 公路桥梁施工安全和质量控制要点
- 水工-建筑物课件
评论
0/150
提交评论