(二叉搜索树即二叉排序树,该题并不是问如何构造最优二叉树,而是如何在二叉搜索树中达成最优搜索效率)

简而言之,这个最优二叉搜索树的每个根节点都大于左子树的任一元素,小于其右子树的任意元素,相当于用根节点x将这个有序集分成了<x的左部分和>x的右部分。

看到这个题目立马就想到了递归与动态规划相结合的思想。根据我们对最优子结构的学习,整体若要取得最优结构,局部也应当取得最优结构,根据动态规划法的思想,我们应当从内到外构建,使得由内到外每一层次都为最优子结构。

设有n=5个关键字的集合,每个在叶节点k i 的概率p i 和在内部结点d i 的概率q i 如表所示:其中 

不过这个题目还引入了存取概率分布的因素,给出一个有序集S以及存取概率分布,因为对于所有元素的每轮搜索只有两种结果:1.在二叉树内部搜索到。2:在叶结点确定x不属于该子树。每个结点所有概率之和即Σa+Σb=1。而对于一个给定的ab概率集合,我们每进行一层搜索,其期望代价花费越高,我们只需对比总体期望代价,总体期望代价越小说明我们访问的结点越少,就越快找到。总的来说,因为我们只知道树是按二叉排序树结构构成的,而不知道具体结点的值和位置,因此需要对比查找到的X数学期望,将期望代价更低的搜索方法视为最优结构。

根据该概率集合可能产生的树结构

期望代价=访问结点数 * 概率

访问结点数=比较次数+1

总体期望代价=每层期望代价之和(最优子结构思想)

如果我们查找的总体期望代价是最低的,就代表这是最优查找

​​

此外还有改进算法,在已知s存储最优子结构的根节点的情况下,用i1,j1区分[i][j]的左右子树期望代价数组m[i][i1],m[j1][j],其中当s[i][j-1]>i,说明i一定在s[i][j-1]的左子树内那么求m[i][j]的期望代价实际就是求左右区间m【i】【s[i][j-1]】和m【i】【s[i+1][j]】的期望代价之和,直接使得i1=s[i][j-1],反之i1=i,j1亦然。直接求出左右子树期望代价最小值

动态规划——最优二叉搜索树相关推荐

  1. 动态规划最优二叉搜索树C语言,【算法导论】动态规划之“最优二叉搜索树”...

    详解动态规划之"最优二叉搜索树" 之前两篇分别讲了动态规划的"钢管切割"和"矩阵链乘法",感觉到了这一篇,也可以算是收官之作了.其实根据前两 ...

  2. 最优二叉搜索树java_动态规划-最优二叉搜索树

    算法思想:动态规划 实际问题:最优二叉搜索树 编写语言:Java 问题描述 二叉搜索树的定义: 满足以下任意两个条件的一个,就可称这棵树为二叉搜索树: 它是一棵空树 该树是一颗二叉树,非空,且满足下列 ...

  3. 动态规划最优二叉搜索树C语言,算法 – 动态规划:最优二叉搜索树

    好吧,我希望有人可以向我解释一下.我正在攻读决赛,我无法解决问题. 问题是动态编程;构造最优二叉搜索树(OBST).我理解一般的动态编程和特别是这个问题的概念,但我不明白这个问题的递归形式. 我得到的 ...

  4. 第十五章 动态规划——最优二叉搜索树

    1.前言: 接着学习动态规划方法,最优二叉查找树问题.二叉查找树参考http://www.cnblogs.com/Anker/archive/2013/01/28/2880581.html.如果在二叉 ...

  5. c语言动态规划最优二叉搜索树,最优二叉搜索树(动态规划)

    #include #include #include #include #include enum:int { MAXVALUE=999 }; template class BestTree{ pri ...

  6. 第十五章 动态规划(最优二叉搜索树)

    第15章动态规划(最优二叉搜索树) 15.5 最优二叉搜索树 15.5 练习 15.5-1 15.5-2 15.5-3 15.5-4 说在前面的话: 为什么单独拿出来发? 1.由于排版篇幅问题,放一起 ...

  7. 动态规划思想——最优二叉搜索树问题(附完整的代码)

    问题: 最优二叉搜索树问题的问题提出是,设S={x1, x2, ..., xn}是一个由n个关键字组成的线性有序集,(a0, b1, a1, ..., bn, an) 为集合S的存取概率分布,表示有序 ...

  8. 【算法设计与分析】动态规划:最优二叉搜索树

    最优二叉搜索树问题的问题提出是,设S={x1, x2, -, xn}是一个由n个关键字组成的线性有序集,(a0, b1, a1, -, bn, an) 为集合S的存取概率分布,表示有序集S的二叉搜索树 ...

  9. 最优二叉搜索树探究【C/C++】

    简述 什么是二叉树 下面的这棵树,就是二叉搜索树 相对于什么最优 这里考虑的是ASL(average search length)平均搜索长度.即根据概率来生成ASL最小的搜索树. 到这里,最优二叉搜 ...

最新文章

  1. win8 下免安装版mysql
  2. linux内核pwn,[内核pwn] 环境搭建
  3. Tomcat启动问题,启动是Tomcat8,结果却是Tomcat9
  4. 异常检测机器学习_使用机器学习检测异常
  5. 城市大脑标准体系与评价指标总体框架研究
  6. 【知识连载】 如何用钉钉宜搭制定企业疫情防控数字化管理方案
  7. 小汤学编程之JDBC(一)——JDBC概述和快速入门
  8. 如何实现一根网线连接路由器,即能上网又可以使用ITV?
  9. 盘点俄罗斯大神写的几款软件,你用过几个?最后1个是我的童年
  10. 怎么批量打印html,Word如何批量打印
  11. 《天勤数据结构》笔记——使用两个栈实现共享栈实现(C/C++)
  12. Android CompoundButton
  13. 天正对应cad版本_2014的天正适用于哪些版本的cad
  14. 如何把多个文件夹里的文件提取出来?
  15. Cosy V3.1.3 简洁大气WordPress博客主题自适应个人自媒体网站模板(含积木部分插件)
  16. 服务器ping值不稳定,服务器网络ping值过高的原因
  17. log4cplus的各种坑
  18. 前后端不分离到分离演变,优势,前后端接口联调,排错
  19. 日常论文分享---持续更新中
  20. Logo(图片)作为报表水印的解决方法

热门文章

  1. 聊聊分布式事务分布式系统事务一致性解决方案
  2. Coordinate Attention
  3. 手机QQ超级萌宠自动培养
  4. Base64编码详解
  5. 搭建虚拟专用网络详解
  6. 社区初鸣,梦想始兴 - 腾讯游戏DBA携手MariaDB开源起航
  7. css html弄出哆啦a梦,用css画一个哆啦A梦
  8. 2018 AI产品趋势:喧嚣的追风者和静默的收割人
  9. 使用fir或者蒲公英来做分发测试
  10. 硬件设计——浮地与接地