查找:基本概念

1.基本概念

1.查找

在数据集合中寻找满足某种条件的数据元素的过程称为查找。

2.查找表(查找结构)

用于查找的数据集合称为查找表,它由同一类型的数据元素(或记录)组成。

3.关键字

数据元素中唯一标识该元素的某个数据项的值,使用基于关键字的查找,查找结果应该是唯一的。

例如:微信号,QQ号

2.查找表的常见操作

1.查找符合条件的数据元素

  • 静态查找表:只需要关注查找速度即可。

2.插入、删除某个数据元素

  • 动态查找表:除了关注查找速度,还需要关注插入,删除是否方便。

3.评价查找算法的指标

1.查找长度

在查找运算中,需要对比关键字的次数称为查找长度。

2.平均查找长度

(ASL,Average Search Length)

所有查找过程中进行关键字的比较次数的平均值。

  1. 计算方法:所有 查找元素的查找长度乘以其对应的概率之和。(通常认为查找任何一个元素的概率都相同)
  2. ASL指标可以运用到二叉排序树。
  3. 通常考虑查找成功、查找失败两种情况下的ASL。
相关推荐
用户938515635075 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC6 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥6 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者8 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者8 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月11 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星12 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星12 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
To_OC1 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode