数据结构(四)——二叉搜索树和平衡二叉树

本文详细介绍了二叉排序树(BST),包括其定义、查找、插入、构造和删除过程。接着讨论了二叉平衡树(AVL),阐述了平衡因子的概念和AVL树的插入调整策略,包括四种旋转操作:LL、RR、LR和RL。
摘要由CSDN通过智能技术生成

1. 二叉排序树(BST)

1.1 二叉排序树的定义

  • 左子树上所有节点的值小于根节点的值。
  • 右子树上所有节点的值大于根节点的值。
  • 对二叉排序树进行中序遍历,可以获得递增的有序序列。

1.2 查找

(1)思想
二叉排序树的查找是从根节点开始,自顶向下比较的过程。

  • 若相等,则查找成功。
  • 当根节点非空时,若小于根节点的值,则在左子树上查找。如大于根节点的值,则在右子树上查找。
  • 函数返回正确节点或NULL值。
/*二叉搜索树的查找(非递归版本)*/
BSTNode* BST_Search(BSTNode* T, int key)
{
   
	while(T != NULL && T->val != key){
   
		if(T->val >key)	T = T->rchild;
		else T = T->lchild;
	}
	return T;		// NULL 或 查找到的节点
}

(2)查找效率分析

  • 最好情况下:即AVL树,n个节点的二叉树最小高度为 [ log ⁡ 2 n ] + 1 [\log_2n]+1 [log<
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冠long馨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值