zoukankan      html  css  js  c++  java
  • [javaSE] 数据结构(AVL树基本概念)

    AVL树是高度平衡的二叉树,任何节点的两个子树的高度差别<=1

     

    实现AVL

    定义一个AVL树,AVLTree,定义AVLTree的节点内部类AVLNode,节点包含以下特性:

    1.key——关键字,对AVL树的节点进行排序

    2.left——左子树

    3.right——右子树

    4.height——高度

     

    如果在AVL树插入节点后可能导致AVL树失去平衡,具体会有四种状态:

    LL:左左,LeftLeft

    LR:左右,LeftRight

    RL:右左,RightLeft

    RR:右右,RightRight

     

    解决上面的情况

    解决LL,需要左单旋转

    解决RR,需要右单旋转

    解决LR,需要先右单旋转,再左单旋转

    解决RL,需要先左单旋转,再右单旋转

     

    实现左单旋转

     

    k1k2

    k2leftk1

    k1rightk2left

    k2k1right

     

    实现右单旋转

    k1k2

    k1rightk2

    k2leftk1right

    k1k2left

     

     

    节点的高度,是它左子树或者右子树中,高度大的那个 再加1

     

    /**
     * AVL树测试
     * @author taoshihan
     * @param <T>
     *
     */
    public class AVLTree<T extends Comparable<T>> {
        private AVLNode mRoot;//根节点
        class AVLNode<T extends Comparable<T>>{
            private T key;//键值
            private int height;//高度
            private AVLNode left;//左子树
            private AVLNode right;//右子树
            public AVLNode(T key,AVLNode left,AVLNode right) {
                this.key=key;
                this.left=left;
                this.right=right;
                this.height=0;
            }
        }
        /**
         * 获取节点高度
         * @param tree
         * @return
         */
        public int height(AVLNode<T> tree){
            if(tree!=null){
                return tree.height;
            }
            return 0;
        }
        /**
         * 取出左右子树中高的那个
         * @param a
         * @param b
         * @return
         */
        public int maxHeight(int a,int b){
            return a>b ? a : b;
        }
        /**
         * 左单旋转
         * @param k2
         * @return
         */
        public AVLNode<T> leftLeftRotation(AVLNode<T> k2){
            AVLNode k1;
            k1 = k2.left;
            k2.left=k1.right;
            k1.right=k2;
            k2.height=maxHeight(height(k2.left), height(k2.right));
            k1.height=maxHeight(height(k1.left), height(k1.right));
            return k1;
        }
        /**
         * 右单旋转
         * @param k2
         * @return
         */
        public AVLNode<T> rightRightRotation(AVLNode<T> k1){
            AVLNode k2;
            k2=k1.right;
            k1.right=k2.left;
            k2.left=k1;
            
            k2.height=maxHeight(height(k2.left), height(k2.right));
            k1.height=maxHeight(height(k1.left), height(k1.right));
            return k2;
        }

     

     

  • 相关阅读:
    poj 1984 Navigation Nightmare(带权并查集+小小的技巧)
    zoj 3261 Connections in Galaxy War(并查集逆向加边)
    poj 1733 Parity game(带权并查集)
    poj 1456 Supermarket(贪心+优先队列)
    hdu 3038 How Many Answers Are Wrong(并查集的思想利用)
    poj 1182 食物链(种类并查集 ‘初心者’)
    hdu 1182 A Bug's Life(简单种类并查集)
    hdu 4725 The Shortest Path in Nya Graph(建图+优先队列dijstra)
    CodeForces 779D. String Game(二分答案)
    poj 3169 Layout(差分约束+spfa)
  • 原文地址:https://www.cnblogs.com/taoshihan/p/5598493.html
Copyright © 2011-2022 走看看