AVL树建立 1066

#include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <stack>
#include <queue>
#include <map>
using namespace std;

struct node  //建立节点
{
    int v,height;
    node* l;
    node* r;
};

node* creatN(int x)  //创建新节点
{
    node* root = new node;
    root ->l = root->r = NULL;
    root ->v = x;
    root ->height = 1;
    return root;
}

int getH(node* root)  //得到子树高度
{
    if(root == NULL) return 0;
    else return root->height;
}

void updateH(node* &root)  //更新子树高度
{
    root->height = max(getH(root->l),getH(root->r)) + 1;
}

void Lrotation(node* &root) //左旋
{
    node* temp = root->r;
    root->r = temp->l;
    temp->l = root;
    updateH(root); //别忘了更新高度
    updateH(temp);
    root = temp;
}

void Rrotation(node* &root) //右旋
{
    node* temp = root->l;
    root->l = temp->r;
    temp->r = root;
    updateH(root); //别忘了更新高度
    updateH(temp);
    root = temp;
}

int getbalance(node* root) //得到平衡因子
{
    return (getH(root->l) - getH(root->r));
}

void insertN(node* &root,int x) //插入
{
    if(root == NULL)
    {
        root = creatN(x);
        return;
    }
    if(x < root->v)
    {
        insertN(root->l,x);
        updateH(root);
        if(getbalance(root) == 2) 
        {
            if(getbalance(root->l) == 1) //LL型
                Rrotation(root); //转移根节点
            else if(getbalance(root->l) == -1) //LR
            {
                Lrotation(root->l); //注意转移节点
                Rrotation(root);
            }
        }

    }
    else if(x > root->v)
    {
        insertN(root->r,x);
        updateH(root);
        if(getbalance(root) == -2)
        {
            if(getbalance(root->r) == -1) //RR
                Lrotation(root); //转移根节点
            else if(getbalance(root->r) == 1) //RL
            {
                Rrotation(root->r); //注意转移节点
                Lrotation(root);
            }
        }
    }
}

int n;
int main()
{
    freopen("1.txt","r",stdin);
    scanf("%d",&n);
    node* root = new node;
    root = NULL;
    for(int i = 0;i<n;i++)
    {
        int t;
        scanf("%d",&t);
        insertN(root,t);
    }
    printf("%d",root->v);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值