AVL树插入算法

没有用到平衡因子。。。

数据结构如下:

struct avl{
	int data;//节点数字
	int frequency;//插入的次数
	int hight;//节点高度
	avl *left;//左子树
	avl* right;//右子树
};

code:

#include<stdio.h>
#include<malloc.h>

struct avl{
	int data;//节点数字
	int frequency;//插入的次数
	int hight;//节点高度
	avl *left;//左子树
	avl* right;//右子树
};
int max(int a,int b){
	return a>b?a:b;}
avl* init(int root_data){

	avl* p=(avl*)malloc(sizeof(avl));
	p->data=root_data;
	p->frequency=1;
	p->left=NULL;
	p->right=NULL;
	p->hight=0;
	return p;
}
int hgt(avl *x)
{
	if(!x)
		return -1;
	return x->hight;
}
void leftrotate(avl * &root){
	avl *tmp=root->right;
	root->right=tmp->left;
	tmp->left=root;
	root->hight=max(hgt(root->left),hgt(root->right))+1;
	tmp->hight=max(hgt(tmp->left),hgt(tmp->right))+1;
	root=tmp;

}
void rightrotate(avl * &root){
	avl *tmp=root->left;
	root->left=tmp->right;
	tmp->right=root;
	root->hight=max(hgt(root->left),hgt(root->right))+1;
	tmp->hight=max(hgt(tmp->left),hgt(tmp->right))+1;
	root=tmp;

}
void LRrotate(avl * &root){
	leftrotate(root->left);
	rightrotate(root);
}
void RLrotate(avl * &root){
	rightrotate(root->right);
	leftrotate(root);
}
void  insert(avl * &root,int x){
	avl *p=init(x);
	if(!root)
		root=p;
	else if(root->data==x)
		root->frequency++;
	else if(root->data>x){
		insert(root->left,x);
		if(hgt(root->left)-hgt(root->right)==2){
			if(x<root->left->data)
				rightrotate(root);	
			else if(x>root->left->data)
				LRrotate(root);	
		}
	}
	else if(root->data<x){
		insert(root->right,x);
		if(hgt(root->right)-hgt(root->left)==2){
			if(x>root->right->data)
				leftrotate(root);	
			else if(x<root->right->data)
				RLrotate(root);	
		}
	}
	root->hight=max(hgt(root->left),hgt(root->right))+1;
}
int main(){

	avl* root=NULL;
	insert(root,3);
	insert(root,7);
	insert(root,8);
	insert(root,2);
	insert(root,1);
	insert(root,9);
	insert(root,5);
	insert(root,10);
}

    原文作者:AVL树
    原文地址: https://blog.csdn.net/mikon_lee/article/details/10336131
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞