版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
5.4.1顺序查找查找又称检索,计算机根据所给条件查找出满足条件的对象,即在存储的一批数据内寻找出一个特定的数据,或者确定在该批数据内是否存在这样的数据。若没有找到满足条件的对象,则返回特定值,表明查找失败;若查找到满足条件的对象,则表明查找成功,一般要求返回该对象的存储位置或对象值本身。通常,程序将按照查找的结果(找到或未找到)来决定接着应执行后面哪一个计算步骤。顺序查找顺序查找又称线性查找,从顺序表的一端开始,依次将每个元素的关键字与给定值key(查找键)进行比较。若某个元素的关键字等于key,则表明查找成功;若所有元素都比较完毕仍找不到,则表明查找失败。如下图所示,在规模为8的数组d中,分别按顺序查找算法寻找数据18和15的情况,处理过程中找到的第4个数组元素d[3]中的数据与18相等,表示8个数据中存在值为18的元素;而若key为15时,查找完所有数据仍未找到,表示8个数据中不存在值为15的元素。18keyd252213181411171901234567到此处已找到15keyd252213181411171901234567查完所有数据仍未找到顺序查找过程实例时间复杂度为O(n)开始i0i≤n-1?d[i]=key?ii+1是否找到,输出信息未找到,输出信息结束顺序查找算法流程图是否实现此算法的Python程序如下:d=[25,22,13,18,14,11,17,19]key=18flag=Falselength=len(d)foriinrange(length):ifd[i]==key:flag=Truebreakifflag=True:print(“查找成功!”)else:print(“未找到”)顺序查找算法也可以写成函数的形式,如下所示:defseq_search(s,a):length=len(s)flag=Falseforiinrange(length):ifs[i]==a:flag=Truebreakifflag==True:returnielse:returnFalsed=[25,22,13,18,14,11,17,19]key=15result=seq_search(d,key)print(result)小结顺序查找本质上是一种枚举算法思想,顺序查找程序就是用循环来枚举所有要查找的对象,然后在循环体内用条件判断当前枚举出的对象是否等于查找对象。假设n个数据依次存储在长度为n的数组a中,查找键为key,自定义函数seq_search(a,key)返回数组a中首个值为key的元素下标,若找不到key则返回-1。defseq_search(a,key):foriinrange(len(a)):ifa[i]==key:returnielse:return-1练一练1.某个列表中共有m个元素,进行顺序查找之后查找失败,则其中元素的比较次数是()A.mB.m2C.m-1D.(m+1)//2A2.有如下python程序段:a=[2,6,8,8,2,4,7,3]p=0foriinrange(1,len(a)):ifa[i]>a[p]:p=i则运行该段代码后,变量p的值为()A.0B.2C.3D.8B3.有如下Python程序段:key=int(input(“key=”))s=0a=[]foriinrange(10):a.append(i+1)foriinrange(len(a)):ifa[i]%key==0:s=s+1print(s)当输入的key=5时,程序运行结束后,输出的值为()A.0B.1C.2D.3C4.查找一个英文句子中是否包含某个单词,可以使用顺序查找的方法,实现上述功能的Python程序段如下,请在划线处填入合适的代码。long=“Ihaveanappleandanorange.”word=input(“输入要查找的单词:”)flag=____________________________foriinrange(len(long)-len(word)):iflong[______________]==word:print(“yes”)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 酒店菜单谋划方案
- 2015年5月15日上午广东省乡镇类公务员面试真题
- 路遥-《人生》-刘巧珍-人物形象-分析
- 2009年7月11日省直机关公务员面试真题
- 他哭了鬼屋作文
- 构建“146”作业管理模式切实提升学生核心素养
- 2013年6月16日上午福建省公务员面试真题
- 北京行政职业能力模拟5
- 长春版小学心理健康教育四年级教案设计
- 一年级品德与生活下册教案
- 加氢裂化催化剂分类及选择
- 政府采购项目验收报告
- 医用耗材配送服务方案
- 《整式的乘法与因式分解》说课稿
- 提高手术患者术前准备完善率医院护理品管圈QCC成果汇报
- 2022年温州市公共资源交易服务中心事业单位工作人员招聘笔试试题及答案解析
- GB/T 324-2008焊缝符号表示法
- GB/T 17669.3-1999建筑石膏力学性能的测定
- 建设工程企业资质改革措施表2020
- GCP-试题含答案及答案2020版
- 消防安全主题班会课件(共17张ppt)
评论
0/150
提交评论