您所在位置: 网站首页 / 数据结构实验报告-查找算法.docx / 文档详情
数据结构实验报告-查找算法.docx 立即下载
2025-08-27
约1.7万字
约29页
0
22KB
举报 版权申诉
预览加载中,请您耐心等待几秒...

数据结构实验报告-查找算法.docx

数据结构实验报告-查找算法.docx

预览

免费试读已结束,剩余 24 页请下载文档后查看

10 金币

下载文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

数据结构实验报告-查找算法

第一篇:数据结构实验报告-查找算法《数据结构》第八次实验报告学生姓名学生班级学生学号指导老师重庆邮电大学计算机学院计算机专业实验中心一、实验内容1)有序表的二分查找建立有序表,然后进行二分查找2)二叉排序树的查找建立二叉排序树,然后查找二、需求分析二分查找的基本思想是将n个元素分成大致相等的两部分,取a[n/2]与x做比较,如果x=a[n/2],则找到x,算法中止;如果xa[n/2],则只要在数组a的右半部搜索x.时间复杂度无非就是while循环的次数!总共有n个元素,渐渐跟下去就是n,n/2,n/4,....n/2^k(接下来操作元素的剩余个数),其中k就是循环的次数由于你n/2^k取整后>=1即令n/2^k=1可得k=log2n,(是以2为底,n的对数)所以时间复杂度可以表示O()=O(logn)下面提供一段二分查找实现的伪代码:BinarySearch(max,min,des)mid-desthenmax=mid-1elsemin=mid+1returnmax折半查找法也称为二分查找法,它充分利用了元素间的次序关系,采用分治策略,可在最坏的情况下用O(logn)完成搜索任务。它的基本思想是,将n个元素分成个数大致相同的两半,取a[n/2]与欲查找的x作比较,如果x=a[n/2]则找到x,算法终止。如果xa[n/2],则我们只要在数组a的右半部继续搜索x。三、概要设计1、顺序查找,在顺序表R[0..n-1]中查找关键字为k的记录,成功时返回找到的记录位置,失败时返回-1,具体的算法如下所示:intSeqSearch(SeqListR,intn,KeyTypek){}inti=0;while(i}if(i>=n){}printf(“%d”,R[i].key);returni;return-1;elseprintf(“%d”,R[i].key);i++;2、二分查找,在有序表R[0..n-1]中进行二分查找,成功时返回记录的位置,失败时返回-1,具体的算法如下:intBinSearch(SeqListR,intn,KeyTypek){}return-1;}intlow=0,high=n-1,mid,count=0;while(lowreturnmid;high=mid-1;low=mid+1;if(R[mid].key>k)else四、详细设计源代码:#include#includestaticinta[1024],count=0;voidFind1(intlow,inthigh,intx){intmid;if(lowx)Find1(low,mid-1,x);elseif(a[mid]voidFind2(intlow,inthigh,intx){intmid;if(lowx)Find2(mid+1,high,x);elseprintf(“n查é找ò到?元a素?位?置?为a%d,?查é找ò次?数簓为a%d。£”,mid,count);}elseprintf(“n查é找ò失骸?败悒?,?查é找ò次?数簓为a%d。£”,count);}intmain(){intn,x;printf(“请?输?入?元a素?个?数簓:”);scanf(“%d”,&n);printf(“n请?按恪?从洙?高?到?低台?或ò从洙?低台?到?高?顺3序ò输?入?各÷元a素?(以?空?格?隔?开a):nn”);for(inti=1;i五、心得体会通过这次在实现顺序和二分查找算法的过程中,让我对顺序和二分查找算法有了更多的了解。查找根据给定的某个值,在查找表中确定一个其关键字等于给定值的数据元素或(记录)的操作,应用十分广泛。顺序查找是一种最简单的查找方法。它的基本思路是:从表的一端开始,顺序扫描线性表,依次将扫描到的关键字和给定值k相比较,若当前扫描到的关键字与k相等,则查找成功;若扫描结束后,仍未找到关键字等于k的记录,则查找失败。二分查找也称为折半查找要求线性表中的结点必须己按关键字值的递增或递减顺序排列。它首先用要查找的关键字k与中间位置的结点的关键字相比较,这个中间结点把线性表分成了两个子表,若比较结果相等则查找完成;若不相等,再根据k与该中间结点关键字的比较大小确定下一步查找哪个子表,这样递归进行下去,直到找到满足条件的结点或者该线性表中没有这样的结点。在学习过程中,善于发现,会找到更多的捷径。六、附录运行结果截图。第二篇:数据结构查找实验报告实验题9.1设计一个程序exp9-1.cpp,输出在顺序表{3,6,2,10,1,8,5,7,4,9}中采用顺序方法找关键字5的过程。程序如下://文件名:exp9-1.cpp#include#defineMAXL100typedefintKeyType;typedefchar
查看更多
单篇购买
VIP会员(1亿+VIP文档免费下)

扫码即表示接受《下载须知》

数据结构实验报告-查找算法

文档大小:22KB

限时特价:扫码查看

• 请登录后再进行扫码购买
• 使用微信/支付宝扫码注册及付费下载,详阅 用户协议 隐私政策
• 如已在其他页面进行付款,请刷新当前页面重试
• 付费购买成功后,此文档可永久免费下载
全场最划算
12个月
199.0
¥360.0
限时特惠
3个月
69.9
¥90.0
新人专享
1个月
19.9
¥30.0
24个月
398.0
¥720.0
6个月会员
139.9
¥180.0

6亿VIP文档任选,共次下载特权。

已优惠

微信/支付宝扫码完成支付,可开具发票

VIP尽享专属权益

VIP文档免费下载

赠送VIP文档免费下载次数

阅读免打扰

去除文档详情页间广告

专属身份标识

尊贵的VIP专属身份标识

高级客服

一对一高级客服服务

多端互通

电脑端/手机端权益通用