计算机科学中, 一个最佳二叉搜索树(Optimal BST),有时也被叫做重量平衡二叉树, 是有可能在已知的一串序列中得到最短搜索时间的一棵二叉搜索树(或期望的搜索时间)。 最优化二叉搜索树可分为两种:静态的和动态的。
静态的最优化问题中,在完全被创建好之前,这棵树是不能被修改的。在这状况中,在这棵树中的每个节点都存在特定的设计,这些设计是依照每个节点被访问的几率去设计出会得到最短的搜索时间。不同的算法能依照每笔数据所给的访问几率去创建或逼近地做出一个静态的最优化树。
动态的最优化问题中,这棵树可以在任何时间被修改,是允许运行树旋转的。 这棵树有一个从树的根开始的指针,他可以借着移动并使用他去修改一棵树。在这状况里,一定会有一连串序列是有着最小的花费,使得这个指针要去走访整棵树去找出这个序列。 伸展树被推测和动态最优化树在任何的情况下都有一个常量比率存在,虽然这还没有被证明出来。