DS06树-二叉排序树选编.ppt

May 0 ?1 Nov 0 0 ?2 ?1 Aug 0 1 1 ?1 Mar 0 0 Apr 0 Jan Jan 0 1 ?1 2 LR 旋转 Mar 0 ?1 May 0 ?1 ?2 ?1 Aug 0 1 0 ?1 Jan 0 0 Apr 0 Nov 0 ?首个“发现者”是May; “麻烦结点”Jan在左子树的右边,因而叫 LR 插入;一般情况(设A是首个发现者)的调整如下: A 1 B 0 BL AR C 0 CR CL LR 插入 A 2 B ?1 BL AR C ?1 CR CL OR LR 旋转 BL AR C 0 A ?1 or 0 CR B 0 or 1 CL OR 左-右双旋 第4章 树 §4.5 AVL树 Dec July Mar 0 ?1 May 0 ?1 ?2 ?1 Aug 0 1 1 ?1 Jan 0 Apr 0 Nov 0 July 0 Dec 0 Feb Feb 0 ?1 1 ?2 2 RL 旋转 July 0 Dec 0 ?1 Aug 0 1 ?2 ?1 Jan 0 1 0 ?1 Feb 0 0 Apr 0 Mar 0 ?1 May 0 ?1 ?2 ?1 1 Nov 0 ?一般情况调整如下: A 1 B 0 BR AL C 0 CL CR RL 插入 A ?2 B 1 BR AL C ?1 CL CR OR RL 旋转 BR AL C 0 A 0 or 1 CL B ?1 or 0 CR OR 第4章 树 §4.5 AVL树 右-左双旋 July 0 Dec 0 ?1 Aug 0 1 ?2 ?1 Jan 0 1 0 ?1 Feb 0 0 Apr 0 Mar 0 ?1 May 0 ?1 ?2 ?1 1 Nov 0 June Oct Sept June 0 ?1 ?1 ?1 2 Nov 0 Dec 0 ?1 Aug 1 ?2 ?1 Feb 0 1 July ?1 Apr 0 Mar 0 May ?1 June 0 Jan 0 Oct 0 ?1 ?2 ?1 ?1 Oct 0 Dec 0 ?1 Aug 1 ?2 ?1 Feb 0 1 July ?1 Apr 0 Mar 0 Nov 0 June 0 Jan 0 May 0 Sept 0 ?1 ?1 ?1 ?1 注意:有时候插入元素即便 不需要调整结构,也可能需要重新计算 一些平衡因子。 第4章 树 §4.5 AVL树 LL、RR、LR、RL四种不平衡情况及其它们的旋转调整算法程序,见教材p.131代码4.20-代码4.22 最后一个问题: 查找和插入的时间复杂性 Tp = O( h ) 其中 h 是二叉树的高度, 但是, h = ? 第4章 树 §4.5 AVL树 设 nh 高度为h的平衡二叉树的最小结点数. 二叉树看起来应该是如下结构形式: 斐波那契序列: F0 = 1, F1 = 1, Fi = Fi?1 + Fi?2 for i 1 ? nh = Fh+2 ? 1, for h ? 0 斐波那契序列的理论值是: 第4章 树 §4.5 AVL树 A h?2 h?1 A h?2 h?1 或 ? nh = nh?1 + nh?2 + 1 ? nh = nh?1 + nh?2 + 1 第4章 树 §4.5 AVL树 设 nh 是高度为h的平衡二叉树的最小结点数. h nh Fh 0 0 0 1 1 1 2 2 1 3 4 2 4 7 3 5 12 5 6 20 8 7 33 13 8 54 21 9 ……………… ? nh = Fh+2 ? 1, (对 h ? 0) ? 给定结点数为 n的AVL树的 最大高度为O(log2n)! ? 从而保证了AVL树的 查找时间性能为O(log2n)! ?二叉排序树的构造与性能 查找二叉搜索树(BST)的时间复杂度(最坏情况下)用查找过程中的比较次数来衡量,它取决于树的深度。 会计算二叉排序树的平均查找长度: 查找

文档评论(0)

1亿VIP精品文档

相关文档