查找:基本概念

1.基本概念

1.查找

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

2.查找表(查找结构)

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

3.关键字

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

例如:微信号,QQ号

2.查找表的常见操作

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

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

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

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

3.评价查找算法的指标

1.查找长度

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

2.平均查找长度

(ASL,Average Search Length)

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

  1. 计算方法:所有 查找元素的查找长度乘以其对应的概率之和。(通常认为查找任何一个元素的概率都相同)
  2. ASL指标可以运用到二叉排序树。
  3. 通常考虑查找成功、查找失败两种情况下的ASL。
相关推荐
前端炒粉3 小时前
35.LRU 缓存
开发语言·javascript·数据结构·算法·缓存·js
断剑zou天涯5 小时前
【算法笔记】窗口内最大值或最小值的更新结构
java·笔记·算法
smj2302_796826525 小时前
解决leetcode第3753题范围内总波动值II
python·算法·leetcode
骑着猪去兜风.7 小时前
线段树(二)
数据结构·算法
fengfuyao9858 小时前
竞争性自适应重加权算法(CARS)的MATLAB实现
算法
散峰而望8 小时前
C++数组(二)(算法竞赛)
开发语言·c++·算法·github
leoufung8 小时前
LeetCode 92 反转链表 II 全流程详解
算法·leetcode·链表
靠沿9 小时前
Java数据结构初阶——Collection、List的介绍与ArrayList
java·数据结构·list
wyhwust9 小时前
交换排序法&冒泡排序法& 选择排序法&插入排序的算法步骤
数据结构·算法·排序算法
利刃大大9 小时前
【动态规划:背包问题】完全平方数
c++·算法·动态规划·背包问题·完全背包