顺序表查找-数据结构

定义 设有一个集合T,其中有n个数据项,集合T及其中数据项的形式如下

T={(k0,I0),(k1,I1),...,(kn-1,In-1)}

k0,k1,...,kn-1是互不相同的关键字值

Ij(0≤j≤n-1)是与关键字值kj相关的信息

给定一个特定的关键字值K,查找问题是在T中确定数据项(kj,Ij),使得kj=K

查找表中的数据项也称为记录

每个记录至少包含一个关键字

记录中关键字的类型可以是能够进行比较操作的任意类型

  • 顺序查找方法

初始时,将给定的关键字值K与表中第一个记录的关键字值相比较,若两个值相等则找到目标,查找成功;否则将K与表中下一个记录的关键字值继续比较并判断是否相等,依此类推。如果直到最后一个记录的关键字值与K都不相等,则表明所存储的数据中没有要查找的目标,查找不成功

查找的平均查找长度为(n+1)/2

不成功查找的查找次数为n

当数据按关键字有序存储时,可以改进顺序查找方法

折半查找也称为二分查找,其适用条件是数组中各个记录按关键字有序排列,所以折半查找只适用于有序表

折半查找并不从有序表的一端开始查找,而是从中间开始查找

  • 例子

给定有序表

11 15 18 22 33 45 60 65 82 86 97

使用折半查找方法查找22,给出查找过程

初始时

相关推荐
编程大师哥4 分钟前
JavaScript 和 Python 哪个更适合初学者?
开发语言·javascript·python
万象.5 分钟前
redis客户端安装与实现C++版本
数据库·c++·redis
Yiyaoshujuku14 分钟前
疾病的发病率、发病人数、患病率、患病人数、死亡率、死亡人数查询网站及数据库
数据库·人工智能·算法
建军啊14 分钟前
php伪协议、代码审计工具和实战
开发语言·php
wen__xvn15 分钟前
基础算法集训第18天:深度优先搜索
算法·深度优先·图论
WYH28719 分钟前
为什么在cubeide里勾选了can1,生成的工程里没有can.c?
c语言·开发语言
梦幻精灵_cq21 分钟前
《双征color》诗解——梦幻精灵_cq对终端渲染的数据结构设计模型式拓展
数据结构·python
22 分钟前
java关于键盘录入
java·开发语言
马猴烧酒.24 分钟前
JAVA后端对象存储( 图片分享平台)详解
java·开发语言·spring·腾讯云
jiang_changsheng27 分钟前
comfyui节点插件笔记总结新增加
人工智能·算法·计算机视觉·comfyui