- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
CONTENTS;/77;省份名称;若整个查找过程都在内存进行,则称之为内查找;反之,若查找过程中需要访问外存,则称之为外查找。;采用何种存储结构?
(1)顺序表
(2)链表
(3)其他;采用何种查找方法?
(1)使用哪种数据结构来表示“表”,即表中记录是按何种方式组织的?
(2)表中关键字的次序。是对无序集合查找还是对有序集合查找?;查找运算时间主要花费在关键字比较上,通常把查找过程中执行的关键字平均比较个数(也称为平均查找长度)作为衡量一个查找算法效率优劣的标准。
平均查找长度ASL(AverageSearchLength)定义为:;成功情况下的平均查找长度
不成功情况(失败)下的平均查找长度。;查找表T:含有n个记录。
成功情况下(概率相等)的平均查找长度ASL成功是指找到T中任一记录平均需要的关键字比较次数。;查找表T:含有n个记录。
不成功情况下的平均查找长度ASL不成功是指查找失败(在T中未查找到)平均需要的关键字比较次数。;线性表查找的主要方法有:
(1)顺序查找
(2)二分查找
(3)分块查找;#defineMAXL表中最多记录个数
typedefstruct
{KeyTypekey; //KeyType为关键字的数据类型
InfoTypedata; //其他数据项
}RecType; //查找顺序表元素类型;思路:从表的一端开始,顺序扫描线性表,依次将扫描到的关键字和给定值k相比较:;顺序查找的算法如下(在顺序表R[0..n-1]中查找关键字为k的元素,成功时返回找到的元素的逻辑序号,失败时返回0):;查找到表中第i个记录R[i-1]时,需比较i次。因此成功时的顺序查找的平均查找长度为:;查找不成功情况时需要和表中所有元素都比较一次,所以,不成功时的平均查找长度为n。;折半查找也称为二分查找,要求线性表中的记录必须己按关键字值有序(递增或递减)排列。
思路:;在关键字有序序列:{1,2,17,25,36,48,60,63,74,89,100}中采用折半查找法查找关键字为63的元素。
程序开始运行,n=11,k=63,此时low=0,high=10,进入循环,计算mid=5。 ;0;intBinSearch(RecTypeR[],intn,KeyTypek)
{
intlow=0,high=n-1,mid;
while(low=high) //当前区间存在元素时循环
{ mid=(low+high)/2;
if(R[mid].key==k) //查找成功返回其逻辑序号mid+1
returnmid+1;
if(kR[mid].key) //继续在R[low..mid-1]中查找
high=mid-1;
else
low=mid+1; //继续在R[mid+1..high]中查找
}
return0;
};思考题
折半查找可以设计成递归算法,如何实现?;二分查找过程可用二叉树来描述:;当n比较大时,将判定树看成内部结点的总数为n=2h-1、高度为h=log2(n+1)的满二叉树(高度h不计外部结点)。树中第i层上的记录个数为2i-1,查找该层上的每个记录需要进行i次比较。;;顺序查找算法;思路:;例如,设有一个线性表,其中包含20个元素,其关键字序列为(18,5,27,13,57,36,38,49,58,63,64,66,71,78,68,80,100,94,88,96);索引表(有序):可以顺序查找块,也可以二分查找块。
数据块(无序):只能顺序查找块中元素。;索引表;18;/77;以二叉树或树作为表的组织形式,称为树表,它是一类动态查找表,不仅适合于数据查找,也适合于表插入和删除操作。;二叉排序树(简称BST)又称二叉查找(搜索)树,其定义为:二叉排序树或者是空树,或者是满足如下性质(BST性质)的二叉树:
?若它的左子树非空,则左子树上所有结点值(指关键字值)均小于根结点值;
?若它的右子树非空,则右子树上所有结点值均大于根结点值;
?左、右子树本身又各是一棵二叉排序树。;二叉树结构;;typedefstructnode
{KeyTypekey; //关键字项
InfoTypedata; //其他数据域
structnode*lchild,*r
您可能关注的文档
- 电子元器件工程项目管理 课件 第八章 创新管理 课件.pdf
- 电子元器件工程项目管理 课件 第二章 组织管理 课件.pdf
- 电子元器件工程项目管理 课件 第九章 管理实例 课件.pdf
- 电子元器件工程项目管理 课件 第六章 风险管理 课件.pdf
- 电子元器件工程项目管理 课件 第七章 沟通管理 课件.pdf
- 电子元器件工程项目管理 课件 第三章 成本管理 课件.pdf
- 电子元器件工程项目管理 课件 第四章 进度管理 课件.pdf
- 电子元器件工程项目管理 课件 第五章 质量管理 课件.pdf
- 电子元器件工程项目管理 课件 第一章 管理理论 课件.pdf
- 数据结构 课件 第1章 绪论(1什么是数据结构) .pptx
- 数据结构 课件 第9章 排序.pptx
- 数据结构(张惠涛) 第三章习题答案及解析.docx
- 数据结构(张惠涛)第六章习题答案及解析.docx
- 数据结构(张惠涛)第七八九章习题答案.docx
- 数据结构(张惠涛)第四章习题答案及解析.docx
- 数据结构(张惠涛)第五章习题答案及解析.docx
- 数据结构(张惠涛)第一章绪论 课后习题答案.docx
- 数据结构(张惠涛)课后题答案 第二章 线性表 .docx
- 案例学AIGC+Photoshop平面设计(微课版)教学大纲 .docx
- 案例学AIGC+Photoshop平面设计(微课版) 课前预习 第1--11章 平面设计发展史---平面设计师的职业要求.pdf
最近下载
- 2025年医疗器械经营质量管理制度、工作程序文件目录.pdf VIP
- 浅谈小学数学核心素养之运算能力.pdf VIP
- 2023年我国蚕桑产业发展态势与未来发展建议.docx VIP
- 电力变压器声纹检测技术导则.docx VIP
- 调度员考核管理细则梳理.docx VIP
- 《建设工程施工合同》GF2024—0201.docx VIP
- 会计师事务所的执业质量控制制度.pdf VIP
- 2021《森林消防队伍基础设施、装备及制度建设标准》.pdf VIP
- 《水利水电工程单元工程施工质量验收评定标准-地基处理与基础工程》(SL 633-2012).pdf VIP
- (高清版)-B-T 2423.18-2021 环境试验 第2部分:试验方法 试验Kb:盐雾,交变(氯化钠溶液).pdf VIP
文档评论(0)