AVL树相关操作

复制代码
#include <iostream>

using namespace std;

//AVL树的节点
template<typename T>
class TreeNode
{
public:
    TreeNode() :lson(NULL), rson(NULL), freq(1), hgt(0){}
    T data;//
    int hgt;//以这个结点为根的树的高度
    int freq;//相同点的频率,我是不知道
    TreeNode* lson, *rson;//左右儿子的地址
};

template<typename T>
class AVLTree
{//AVLTree的类属性和方法声明
private:
    TreeNode<T>*root;//根节点
    void insertpri(TreeNode<T>*&node, T x);//插入
    TreeNode<T>* findpri(TreeNode<T>* node, T x);//查找
    void traversalpri(TreeNode<T>* node);//遍历
    void delpri(TreeNode<T>* &node, T x);//删除
    int height(TreeNode<T>* node);//辅助操作:高度
    void singLeft(TreeNode<T>* &k2);//左左操作
    void singRight(TreeNode<T>* &k2);//右右操作
    void doubleLeft(TreeNode<T>* &k3);//左右操作
    void doubleRight(TreeNode<T>* &k3);//右左操作
    int max(int cmpa, int cmpb);
public:
    AVLTree() :root(NULL){};
    void insert(T x);//插入接口
    void del(T x);//删除接口
    TreeNode<T>* find(T x);//查找接口
    void traversal();//遍历接口
};

//辅助操作:高度
template<typename T>
int AVLTree<T>::height(TreeNode<T>* node)
{
    if (node!=NULL)
        return node->hgt;
    return -1;
}

//辅助操作:比较高度
template<typename T>
int AVLTree<T>::max(int cmpa, int cmpb)
{
    return cmpa > cmpb ? cmpa : cmpb;
}

template<typename T>
void AVLTree<T>::singLeft(TreeNode<T>* &k2)
{//左左情况下旋转
    TreeNode<T>* k1;
    k1 = k2->lson;
    k2->lson = k1->rson;
    k1->rson = k2;
    k2 = k1;
    k2->hgt = max(height(k2->lson), height(k2->rson))+1;
    k1->hgt = max(height(k1->lson), height(k1->rson))+1;
}

template<typename T>
void AVLTree<T>::singRight(TreeNode<T>* &k2)
{//左左情况下旋转
    TreeNode<T>* k1;
    k1 = k2->rson;
    k2->rson = k1->lson;
    k1->lson = k2;
    k2 = k1;
    k2->hgt = max(height(k2->lson), height(k2->rson))+1;
    k1->hgt = max(height(k1->lson), height(k1->rson))+1;
}

template<typename T>
void AVLTree<T>::doubleLeft(TreeNode<T>* &k3)
{//左右的情况
    singRight(k3->lson);
    singLeft(k3);
}

//右左的情况
template<typename T>
void AVLTree<T>::doubleRight(TreeNode<T>* &k3)
{
    singLeft(k3->rson);
    singRight(k3);
}

//插入
template<typename T>
void AVLTree<T>::insertpri(TreeNode<T>* &node, T x)
{
    if (node == NULL)
    {
        node = new TreeNode<T>();
        node->data = x;
        return;
    }
    if (node->data>x)
    {
        insertpri(node->lson, x);//递归插入
        //插入后自我调整
        if (2 == height(node->lson) - height(node->rson))
        if (node->lson->data < x)
            doubleRight(node);
        else
            singLeft(node);
    }
    else if (node->data < x)
    {
        insertpri(node->rson, x);
        if (2 == height(node->rson) - height(node->lson))
        if (node->rson->data < x)
            singRight(node);
        else
            doubleRight(node);
    }
    else ++(node->freq);
    //取新的高度值,后面的+1很重要,作者都忘记了加
    node->hgt = max(height(node->lson), height(node->rson)) + 1;
}

//插入接口
template<typename T>
void AVLTree<T>::insert(T x)
{
    insertpri(root, x);
}

//查找
template<typename T>
TreeNode<T>* AVLTree<T>::findpri(TreeNode<T>* node, T x)
{
    if (node == NULL)
        return NULL;
    if (node->data > x)
        return findpri(node->lson, x);
    else if (node->data < x)
        return findpri(node->rson, x);
    else return node;
}

//查找
template<typename T>
TreeNode<T>* AVLTree<T>::find(T x)
{
    findpri(root, x);
}

//删除
template<typename T>
void AVLTree<T>::delpri(TreeNode<T>* &node,T x)
{
    if (node == NULL)
        return;
    if (x < node->data)
    {
        delpri(node->lson, x);
        //删除后的调整
        if (2 == height(node->rson) - height(node->lson))
        if (node->rson->lson&&height(node->rson->lson) > height(node->rson->rson))
            doubleRight(node);
        else
            singRight(node);
    }
    else if (x > node->data)
    {
        delpri(node->rson, x);
        if (2 == height(node->lson) - height(node->rson))
        if (node->lson->rson&&height(node->lson->rson) > height(node->lson->lson))
            doubleLeft(node);
        else
            singLeft(node);
    }
    else//找到后的操作
    {//先是有两个儿子的情况
        if (node->lson&&node->rson)
        {
            TreeNode<T>* t = node->lson;
            for (; t->rson; t = t->rson);
            node->data = t->data;
            node->freq = t->freq;
            //递归到一个儿子或没有儿子的情况
            delpri(node->lson, t->data);
            if (2 == height(node->rson) - height(node->lson))
            {//下面的if自己不会写
                if (node->rson->lson&&height(node->rson->lson) > height(node->rson->rson))
                    doubleRight(node);
                else
                    singRight(node);
            }
        }
        else
        {
            TreeNode<T>* t = node;
            if (node->lson == NULL)
                node = node->rson;
            else if (node->rson == NULL)
                node = node->lson;
            delete(t);
            t = NULL;
        }
    }
    if (node == NULL)return;//表示只有根节点,删了之后就没有了
    node->hgt = max(height(node->lson), height(node->rson));
    return;
}

template<typename T>
void AVLTree<T>::del(T x)
{
    delpri(root, x);
}

//中序遍历函数
template<class T>
void AVLTree<T>::traversalpri(TreeNode<T>* node)
{
    if (node == NULL) return;
    traversalpri(node->lson);//先遍历左子树
    cout << node->data << " ";//输出根节点
    traversalpri(node->rson);//再遍历右子树
}
//中序遍历接口
template<class T>
void AVLTree<T>::traversal()
{
    traversalpri(root);
}

int main()
{
    AVLTree<int> t;
    t.insert(3);
    t.insert(2);
    t.insert(1);
    t.insert(4);
    t.insert(5);
    t.insert(0);
    t.del(2);
    t.insert(2);
    t.traversal();
}
复制代码

 

posted on   Kooing  阅读(160)  评论(0编辑  收藏  举报

努力加载评论中...

导航

点击右上角即可分享
微信分享提示