实验二-折半查找算法设计.docx

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
PAGE PAGE 1 / 4 实验二 折半查找算法设计 题目:折半查找算法设计 问题描述:(1)分析掌握折半查找算法思想,在此基础上,设计出递归算法和循环结构两种实现方法的折半查找函数。 )编写程序实现: 在保存于数组的 10000 个有序数据元素中查找数据元素 x 是否存在。数据元素 x 要包含两种情况:一种是数据元素 x包含在数组中;另一种是数据元素 x 不包含在数组中 )数组中数据元素的有序化既可以初始赋值时实现, 也可以设计一个排序函数实现。 )根据两种方法的实际运行时间, 进行两种方法时间效率的分析对 比。 基本要求:(1)10000 个数据可以初始赋值时实现, 也可以调用系统的随机函数, 再设计一个排序函数实现。 )两种方法时间效率的分析对比可以有两种方法, 一种是理论分析方法,一种是实际记录运行时间。 提交实验报告。 测试数据:运行算法时,当输入的数据小于 10000,例如输入 9999 时,显示该数据在数组中,下标为 9998,并且分别显示递归和循环结构下的时 间;当输入的数据大于 10000 时,例如输入 20000 时,显示这个这个数据不再该数组中。 算法思想:设有数组 a 中元素按从小到大的次序排列, a 的下界下标为 low , 上界下标为 high,首先计算出 a 的中间位置下标 mid=( low+high)/2, 1.递归算法思想:比较 x 和 a[mid], 若 x=a[mid] ,则查找成功;若xa[mid] ,则随后调用算法自身在下标为 low ,上界下标为 mid-1 的区间继续查找;若 xa[mid] ,则随后调用算法自身在下标为 mid+1, 上界下标为 high 的区间继续查找。当查找区间小于等于 0 时,查找过程结束。 2.循环结构思想:用 while(low = high) 控制循环,比较 x 和 a[mid] , 若 x=a[mid] ,则查找成功;若 xa[mid] ,则随后在下标为 low ,上界下标为 mid-1 的区间继续查找; 若 xa[mid] ,则随后在下标为 mid+1, 上界下标为 high 的区间继续查找。当查找区间小于等于 0 时,查找过程结束。 模块划分: 1. 头文件 time.h 中包含 time()和 difftime(end,start)函数,分别实现取系统当前时间和 end 减去 start的时间差; 2.头文件 stdlib.h 中包含 rand()函数,实现随机数的生成; 3.void list(int a[]) 实现对随机数从小到大的排序; int Search(int a[],int low,int high,int x) 用递归算法实现折半查找数据元素的函数; int BSearch(int a[], int low, int high, int x) 用循环结构实现折半查找数据元素的函数; void main()主函数,测试用递归算法和循环结构实现折半查找数据元素的函数。 数据结构: 源程序: #includestdio.h #includetime.h int Bsearch(int a[],int x,int low,int high) { int mid; if(lowhigh) return -1; mid=(low+high)/2; if(x==a[mid]) return mid; else if(xa[mid]) Bsearch(a,x,low,mid-1); else }  return Bsearch(a,x,mid+1,high); int Csearch(int test[],int x,int low,int high) { for(int i=0;ihigh;i=(low+high)/2) { if(x==test[i]) return i; else if(xtest[i]) low=i+1; else high=i-1; } if(i=high) return -1; } void main() { time_t start,end; double dif; int Bsearch(int a[],int x,int low,int high); int Csearch(int test[],int x,int low,int high); int a[10000],x; int low=0,high=10000,mid=0; printf( 请输入要查找的元素: \n); scanf(%ld,x); printf(x=%ld\n,x); for(int i=0;ihigh;i++) a[i]=i+1; int bn; time(start); bn=Bsearch(a,x,0,1

文档评论(0)

文档查询,农业合作 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体土默特左旗农特农机经销部
IP属地内蒙古
统一社会信用代码/组织机构代码
92150121MA0R6LAH4P

1亿VIP精品文档

相关文档