左偏树

9 篇文章 0 订阅
6 篇文章 0 订阅
</pre><pre name="code" class="cpp">#include<stdio.h>
#include<stdlib.h>
typedef struct node
{
	int key,dist;
	struct node *Left,*Right;
}LeftistTree;
void Swap(LeftistTree** a,LeftistTree** b)
{
	LeftistTree *tmp;
	tmp = *a;
	*a = *b;
	*b = tmp;
}
LeftistTree* Merge(LeftistTree *A,LeftistTree *B)
{
	if(A == NULL) 
		return B;
	if(B == NULL)
		return A;
	if(A->key < B->key)
	{
		Swap(&A,&B);
	}
	A->Right = Merge(A->Right,B);
	if(A->Left == NULL)
	{
		A->Left = A->Right;
		A->Right = NULL;
	}
	else 
		if(A->Right)
			if(A->Right->dist > A->Left->dist)
				Swap(&A->Left,&A->Right);
	if(A->Right == NULL)     
		A->dist = 0;
	else                
		A->dist = A->Right->dist + 1;
	return A;
}
LeftistTree* MakeIntoTree(int x)
{
	LeftistTree *T;
	T = (LeftistTree*)malloc(sizeof(LeftistTree));
	T->key = x;
	T->dist = 0;
	T->Left = T->Right = NULL;
	return T;
}
LeftistTree* Insert(LeftistTree* A,int x)
{
	LeftistTree *B;
	B = MakeIntoTree(x);
	A = Merge(A,B);
	return A;
}

/*删除最大节点*/
int DeleteMax(LeftistTree** A)
{
	int t = (*A)->key;
	*A = Merge((*A)->Left,(*A)->Right);
	return t;
}
/*中序输出*/
void InOrder(LeftistTree* T)
{
	if(T->Left)
		InOrder(T->Left);
	printf("%d %d\n",T->key,T->dist);
	if(T->Right)
		InOrder(T->Right);
}
int main(void)
{
	LeftistTree* T = NULL;
	int n,a;
	scanf("%d",&n);
	while(n --)
	{
		scanf("%d",&a);
		T = Insert(T,a);
		InOrder(T);
	}
	DeleteMax(&T);
	printf("\n");
	InOrder(T);
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值