4.5最优检索树.pptVIP

  1. 1、本文档共22页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
4.5最优检索树,最优二分检索树,最优二叉树,最优二叉树算法,最优二叉搜索树,最优比率生成树,最优二叉查找树,最优比例生成树,最优二叉树权值,最优归并树

* §5. 最优检索树 检索,search就是member(a, S), 序列σ是一系列的member指令。 * ∴有一个造树的问题,用谁做根? 例如: 因为不但要检索a∈S,而是一般地要检索a∈U (S是U中的一个子集)。 对于全集U中所有元素a,给出指令Member(a,S)在σ中出现的概率。为S设计一棵二叉查找树,以期望的最小比较次数在线处理Member指令序列σ。 二叉查找树的代价cost * 设S: a1,a2,…,an 且ai<ai+1(升序排列,假设无相等元) 令, Pi代表MEMBER(ai,S)指令(a∈S)在σ中出现的频率, qi代表MEMBER(a,S)指令(a S)在σ中出现的频率,其定义为: q0 MEMBER(a, S) a<a1 qi MEMBER(a, S) ai<a<ai+1 qn MEMBER(a, S) a>an * 例如, 有U: 0、begin、1、else、2、end、3、if、4、then、5 有S: begin、else、end、if、then (i 是U-S中的元,0≤i≤n) 为了定义二叉查找树的代价cost,可加入n+1个叶子,以便构造集合U-S中元素的映射,称这些叶子为0,1,…,n * 下面定义二叉查找树的代价,显然: 如果a∈S,例如,a=l(v), 那么,比较次数=depth(v)+1;(加1为比较根的花费) 如果a S,那么,比较次数=depth(i); (∵ i是叶,且是U-S中的元) ∴ 我们定义可期比较次数为T的费用CT , * 以上面的例子,假定|S|=5,且假定|U-S|=6 即,有U: 0、begin、1、else、2、end、3、if、4、then、5 有S: begin、else、end、if、then 其中,小于和大于S的元共2个:|0|+|5|=2 满足ai<a<ai+1的元共4个:|1|+|2|+|3|+|4|=4 那么, , , , 似乎是等概率,但实际情况并非如此! * 如何使费用CT最小? 动态规划 设Tij为T的最优子树,其节点为: ai+1,……,aj 0≤i<j≤n Cij为Tij的费用; rij ………… 根; wij ……….. 权;weight(即出现概率之和) wij = qi + ( pi+1 + qi+1 ) + ,……, + ( pj + qj ) * 例如,end的子树begin,有w02 w02 = q0 + ( p1 + q1 ) + ( p2 + q2 ) T12是begin的子树,Tii是空树, Cii=0, 但是wii= qi, ∵ i个元在U-S中,还有可能MEMBER(i, S)在σ中出现, 但其费用Cii=0,(i子树的深度为0) * 一般情况,需考虑2n个子树,每个子树有2个可能根。 树Tij: 若rij为ak∈S,那么它有2个子树,2个子树的每个节的深度Depth在Tij(母树)中都增加1. ∴ Cij = Ci,k-1 + Ck,j + Wi,k-1 + Pk + Wk,j * 其中,(Wi,k-1 + Pk + Wk,j)为深度加1所增加的,也可认为是查找Root的花费。 wi,k-1= qi + ( pi+1 + qi+1 ) + ,……, + ( pk-1 + qk-1 ) wk,j = qk + ( pk+1 + qk+1 ) + ,……, + ( pj + qj ) pk = pk 以上三式相加: wi,k-1 + wk,j + pk = wij ∴ Tij 的费用: Cij = Ci,k-1 + Ck,j + Wij * 要Cij最小,将找出k(i<k≤j) ,使Ci,k-1 + Ck,j 最小。也就是要找

文档评论(0)

badjka + 关注
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档