第17讲 查找1.pptxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第17讲 查找1

数据结构主讲人:陈红丽第7章 查找教学目标1.熟练掌握顺序表和有序表(折半查找)的查找算法及其性能分析方法;2.熟练掌握二叉排序树的构造和查找算法及其性能分析方法;3. 理解二叉排序树的插入算法和删除方法;4.熟练掌握哈希函数(除留余数法)的构造5.熟练掌握哈希函数解决冲突的方法及其特点 教学内容7.1 查找的基本概念7.2 线性表的查找7.3 树表的查找7.4 哈希表的查找第17讲是一种数据结构7.1 查找的基本概念查找表: 由同一类型的数据元素(或记录)构成的集合静态查找表: 查找的同时对查找表不做修改操作(如插入和删除)动态查找表: 查找的同时对查找表具有修改操作关键字 记录中某个数据项的值,可用来识别一个记录主关键字: 唯一标识数据元素次关键字: 可以标识若干个数据元素查找算法的评价指标关键字的平均比较次数,也称平均搜索长度ASL(Average Search Length)n:记录的个数pi:查找第i个记录的概率 ( 通常认为pi =1/n )ci:找到第i个记录所需的比较次数查找的方法取决于查找表的结构 为了提高查找的效率, 需要在查找表中的元素之间人为地附加某种确定的关系,换句话说,用另外一种结构来表示查找表。1、线性表2、 树3、哈希表查找的分类:比较式查找法:直接比较关键字(1)线性表的静态查找(2)二叉排序树的动态查找计算式查找法:计算记录所在的地址。 也称为HASH(哈希)查找法。7.2 线性表的查找一、顺序查找(线性查找)二、折半查找(二分或对分查找)三、分块查找顺序查找查找表的表示typedef struct { ElemType *R; //表基址 int length;//表长}SSTable;应用范围: 顺序表或线性链表表示的静态查找表 表内元素之间无序typedef struct { //数据元素类型 keyType key; // 关键字域 InfoType otherinfo;} ElemType , TElemType ;第2章在顺序表L中查找值为e的数据元素查找方向ii查找方向int Search_Seq( SSTable ST , KeyType key ){ //若成功返回其位置信息,否则返回0 ST.R[0].key =key; //监视哨 for( i=ST.length; ST.R[ i ].key!=key; - - i ) ; return i; }int LocateELem(SqList L,ElemType e){ for (i=0;i L.length;i++) if (L.elem[i]==e) return i+1; return 0;}查找K=35查找K=38哨兵0 1 2 3 4 5 67 … 1923 75 41 38 54 62 173538改进:把待查关键字key存入表头(“哨兵”),从后向前逐个比较,可免去查找过程中每一步都要检测是否查找完毕,加快速度。顺序查找的性能分析int Search_Seq( SSTable ST , KeyType key ){ //若成功返回其位置信息,否则返回0 ST.R[0].key =key; //监视哨 for( i=ST.length; ST.R[ i ].key!=key; - - i ) ; return i; }算法简单,对表结构无任何要求(顺序和链式)n很大时查找效率较低改进措施:非等概率查找时,可按照查找概率进行排序。空间复杂度:一个辅助空间。时间复杂度:1) 查找成功时的平均查找长度 设表中各记录查找概率相等 ASLs(n)=(1+2+ ... +n)/n =(n+1)/22)查找不成功时的平均查找长度ASLf =n+1练习:判断对错n个数存在一维数组A[1..n]中,在进行顺序查找时,这n个数的排列有序或无序其平均查找长度ASL不同。 查找概率相等时,ASL相同;查找概率不等时,如果从前向后查找,则按查找概率由大到小排列的有序表其ASL要比无序表ASL小。 折半查找若k==R[mid].key,查找成功若kR[mid].key,则high=mid-1若kR[mid].key,则low=mid+1low=1mid=7 high=13mid=3 high=6 high=2 mid=1 low=2mid=2 例:查找key为14的记录 0 1 2 3 4 5 6 7 8 9 10 11 12 13 7 14 18 21 23 29 31

文档评论(0)

2232文档 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档