平均查找长度 (ASL)

不知道为什么最近喜欢写一些理论性并且与算法无关的知识,可能是因为初赛题刷多了且知识点不难,所以对这些新鲜的知识点有好感,那今天就写一篇ASL的文章,诸君就当小说看着玩吧 ?

平均查找长度

是为确定记录在查找表中的位置,需和给定值进行比较的关键字个数的期望值。(Average Search Length,ASL)

百科的概念有些难懂,这里的长度其实不是一个具体的长度,而是衡量一个算法时间性能的数值,在许多算法中我们都需要查找某个值,或者是对某个值做更改,既然要做更改那就必须先找到你所要查找的数,再将其更改为自己所需要的数,可见查找这一行为的普遍。
而当查找的时候,花费的时间大多在值与值的比较中,比如,判断相等要写if,判断dp的容积有没有越界,也要写if,所以把平均需要/和待查找值比较的/关键字次数/称为平均查找长度。(为读者断句,方便理解)

ASL既然与比较次数,也就是查找次数有关,那么其定义如下式:
A S L = ∑ i = 1 n P i C i ASL=\sum_{i=1}^n P_iC_i ASL=i=1nPiCi

其中n为查找表中元素个数,Pi为查找到第i个元素的概率,通常设每个元素查找概率相同,即Pi=1/n,Ci是找到第i个元素的所需要的比较次数。
注意:ASL只能用于静态查找表中顺序表的查找,如果你的一个表是动态的,即表中的数值时时刻刻都在变动,其出现的概率也会变动,就会影响 P i × C i P_i\times C_i P

  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值