二叉排序树和平衡二叉树(哈喜老师)

1.二叉排序树

1.1:二叉排序树的概念

1.2:与二叉排序树的相关的操作

1.2.1:求平均查找长度

1.2.2:查找某个元素

代码 (不重要)
cpp 复制代码
// 代码不重要,重要的是要明白查找某个元素的过程
// 二叉排序树(BST)的查找函数
// 参数:T 是二叉排序树根节点,key 是要查找的关键字(元素)
// 返回值:找到则返回对应节点指针,没找到则返回 NULL
BSTNode *BST_Search (BiTree T, ElemType key) {
    // 循环条件:树不为空 且 还没找到目标关键字
    while (T != NULL && key != T->data) {
        if (key < T->data)
            T = T->lchild;    // 关键字 < 当前节点值 → 去左子树查找
        else
            T = T->rchild;    // 关键字 > 当前节点值 → 去右子树查找
    }
    // 退出循环:要么找到节点,返回该节点的地址,要么T=NULL(查找失败)
    return T;
}

1.2.3:在二叉排序树中插入元素

代码 (不重要)
cpp 复制代码
// 代码不重要,重要的是要明白插入某个元素的过程
// 二叉排序树的插入函数(递归实现)
// 参数:&T 为二叉排序树根节点的引用,k 为待插入的关键字
// 返回值:插入成功返回 1,失败(关键字已存在)返回 0
int BST_Insert(BiTree &T, KeyType k) {
    // 情况1:当前子树为空,找到插入位置
    if (T == NULL) {
        // 为新节点分配内存空间
        T = (BiTree)malloc(sizeof(BSTNode));
        // 将关键字存入新节点
        T->data = k;
        // 新节点为叶子节点,左右孩子初始化为空
        T->lchild = T->rchild = NULL;
        return 1;    // 插入成功,返回1
    }
    // 情况2:树中已存在相同关键字的节点,不允许重复插入
    else if (k == T->data) {
        return 0;    // 插入失败,返回0
    }
    // 情况3:待插入关键字小于当前节点值,递归插入到左子树
    else if (k < T->data) {
        return BST_Insert(T->lchild, k);
    }
    // 情况4:待插入关键字大于当前节点值,递归插入到右子树
    else {
        return BST_Insert(T->rchild, k);
    }
}
例题:

1.2.4:删除二叉排序树中的某个元素 (这里听王道的课,知识点不常考)

习题1:(易)
习题2:(难)
相关推荐
木子墨5162 小时前
工程算法实战 | 从LRU到手写本地缓存:LinkedHashMap → 双向链表+哈希表 → Caffeine 原理
java·数据结构·算法·链表·缓存
流年如夢2 小时前
二叉树(LeetCode)
数据结构·算法·leetcode·职场和发展
玉树临风ives3 小时前
atcoder ABC 457 题解
数据结构·c++·算法
驭渊的小故事3 小时前
Java数据结构集合框架(栈(Stack)的详细解析)2000字详细解析
数据结构
宵时待雨4 小时前
回溯算法专题1:递归
数据结构·c++·笔记·算法·leetcode·深度优先
如竟没有火炬4 小时前
去除重复字母——贪心+单调栈
开发语言·数据结构·python·算法·leetcode·深度优先
风味蘑菇干5 小时前
斗地主案例
java·数据结构·算法
Languorous.5 小时前
C++数据结构高阶|B+树深度解析:从底层原理到数据库应用,面试高频考点全覆盖
数据结构·b树·面试
人道领域5 小时前
【LeetCode刷题日记】222.极速计算完全二叉树节点数:O(log²n)算法揭秘
java·数据结构·算法·leetcode·深度优先