登录
首页 >  文章 >  java教程

设计 AVL 树的类

来源:dev.to

时间:2024-07-25 08:42:43 135浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个文章开发实战,手把手教大家学习《设计 AVL 树的类》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

由于 AVL 树是二叉搜索树,因此 AVLTree 被设计为 BST 的子类。 AVL 树是二叉树,因此您可以定义 AVLTree 类来扩展 BST 类,如下图所示。 BSTTreeNode类在Section.

中定义

设计 AVL 树的类

为了平衡树,你需要知道每个节点的高度。为了方便起见,将每个节点的高度存储在AVLTreeNode中,并将AVLTreeNode定义为BST.TreeNode的子类。请注意,TreeNodeBST 中被定义为静态内部类。 AVLTreeNode 将被定义为AVLTree 中的静态内部类。 TreeNode 包含数据字段elementleftright,它们由AVLTreeNode继承。因此,AVLTreeNode包含四个数据字段,如下图所示。

设计 AVL 树的类

BST 类中,createNewNode() 方法创建一个 TreeNode 对象。此方法在 AVLTree 类中被重写,以创建 AVLTreeNode。注意,BST类中的createNewNode()方法的返回类型是TreeNode,但AVLTree类中的createNewNode()方法的返回类型是AVLTreeNode。这很好,因为AVLTreeNodeTreeNode的子类。

AVLTree 中搜索元素与在常规二叉树中搜索相同,因此 BST 类中定义的 search 方法也适用于 AVLTree.

重写insertdelete方法来插入和删除元素,并在必要时执行重新平衡操作以确保树平衡。

以上就是《设计 AVL 树的类》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>