不知道为什么最近喜欢写一些理论性并且与算法无关的知识,可能是因为初赛题刷多了且知识点不难,所以对这些新鲜的知识点有好感,那今天就写一篇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=1∑nPiCi
其中n为查找表中元素个数,Pi为查找到第i个元素的概率,通常设每个元素查找概率相同,即Pi=1/n,Ci是找到第i个元素的所需要的比较次数。
注意:ASL只能用于静态查找表中顺序表的查找,如果你的一个表是动态的,即表中的数值时时刻刻都在变动,其出现的概率也会变动,就会影响 P i × C i P_i\times C_i P