最优二分树
来源:互联网 发布:淘宝没有优酷会员卖了 编辑:程序博客网 时间:2024/06/03 02:26
给定四个点:A,B,C,D,它们的查找概率分别为0.3,0.1, 0.2,0.4,(概率*10作为节点代价)
采用动态规划的思想给出最优二分搜索树。
首先 给出一个以K为根查找从i到j的 求解最优代价的公式:Cij=C(i,k-1) + C(k+1,j) +P(ij), ijk都表示下标,P(ij)表示从i到j的权重之和。(i<=k<=j)
下面开始计算过程:
从第n+1个节点开始,标号前面的数比后面的数大,则表示空树。
C(5,4)=0,表示代价;R(5,4)=-1,表示树根
C(4,3)=0, R(4,3)=-1
C(4,4)=4,R(4,4)=4,
C(3,2)=0, R(3,2)=-1,
C(3,3)=2, R(3,3)=3 ,
C(3,4)=C(3,2)+C(4,4)+P(3,4)=0+4+6=10
=C(3,3)+C(5,4)+P(3,4)=2+0+6=8 (8<10) 所以R(3,4)=4
C(2,1)=0, R(2,1)=-1,
C(2,2)=1, R(2,2)=2
C(2,3)=C(2,1)+C(3,3)+P(2,3)=5
=C(2,2)+C(4,3)+P(2,3)=4 所以R(2,3)=3
C(2,4)=C(2,1)+C(3,4)+P(2,4)=15
=C(2,2)+C(4,4)+P(2,4)=12
=C(2,3)+C(5,4)+P(2,4) =11 所以R(2,4)=4
C(1,0)=0, R(1,0)=-1
C(1,1)=3, R(1,1)=1;
C(1,2)=C(1,0)+C(2,2)+P(1,2)=5
=C(1,1)+C(3,2)+P(1,2)=7, 所以R(1,2)=2
C(1,3)=C(1,0)+C(2,3)+P(1,3)=10
=C(1,1)+C(3,3)+P(1,3)=11
=C(1,2)+C(4,3)+P(1,3)=11 所以R(1,3)=1
C(1,4)=C(1,0)+C(2,4)+P(1,4)
=C(1,1)+C(3,4)+P(1,4)
=C(1,2)+C(4,4)+P(1,4)=19 所以R(1,4)=3
=C(1,3)+C(5,4)+P(1,4)
所以最优二分搜索树为(((A)-B)-C-(D))
- 最优二分搜索树
- 最优二分搜索树
- 最优二分树
- 最优二分查找树
- 最优二分检索树讲解
- 动态规划---->最优二分检索树
- 动态规划-最优二分检索树
- 算法——最优二分检索树
- 动态规划_最优二分查找树
- 动态规划:最优二分检索树
- POJ 2728 Desert King(最优比率生成树) prim+二分
- POJ 2728 (最优比率生成树+二分或者迭代)
- UVA10304-Optimal Binary Search Tree(最优二分检索树)
- poj2728 Desert King(最优比率生成树,二分答案+prim)
- Cyclic Tour (最优二分匹配)
- hdu2255 (二分图最优匹配)
- 二分图最优完美匹配
- 二分图最优匹配 模板
- Windows 域角色的理解(FSMO角色的概念)及优化配置
- 两分钟彻底让你明白Android Activity生命周期(图文)!
- java做下载的时候docx文件的时候变成.zip后缀的问题
- Hadoop源代码的边角料:HDFS的数据通信机制
- ld: framework not found IOKit
- 最优二分树
- Histogram Calculation
- jQuery.getJSON(url, [data], [callback])[通过url,文件。txt,带参数三种方式](十三)
- Oracle Secure Backup管理员指南 第2章 管理用户和类
- 能使 Oracle 索引失效的七大限制条件
- 游戏机解禁背后:千亿市场开放 多家厂商抢蛋糕
- 2013 CocoaChina微信精选之技术汇
- webservice之获取天气预报
- Entity Framework 5.0系列之EF概览