• 数据结构与算法-二叉排序树


    前言

    查找和排序是算法中最基础的两类算法,其或多或少会被应用在其他高阶算法中。每一种算法都可以有多种数据结构作为支撑,比如查找,可以是对于无序顺序表的查找,查找时只能顺序遍历了;可以是有序顺序表的查找,可以进行二分查找;还可以是即将要介绍的二叉排序树的查找,其查找逻辑类似于二分查找,在插入元素时又不需要大量的移动操作。

    定义

    二叉排序树又叫做二叉查找树,在数的内部维护着一种秩序,即任何子树的左子树都小于该子树的树根,右子树都大于该子树的树根,这样在查找逻辑就会类似二分查找,这种秩序是在插入元素时得到维持的。

    由于二叉排序树的特性,其再求最值、Floor、Ceiling时也是有规律的。

    最大最小值

    Floor和Ceiling

    查找Floor(key)的值就是所有<=key的最大值,相反查找Ceiling的值就是所有>=key的最小值,下图是Floor函数的查找示意图:

    删除

     缺陷

    二叉排序树在搜索逻辑上类似二分查找,实现也比较简单,但与二分查找一样,极端情况下可能会编程顺序查找(如下图的worst case),也正是因为这种缺陷,排序二叉树很少应用于工程,所以才会出现平衡二叉树。

  • 相关阅读:
    datatable转json
    GridView 自定义表头
    jquery之each
    验证码
    C# 添加,修改,删除文件夹/文件集合
    SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
    bootstrap 简易模版
    容易上手-类似ERP系统 简单特效
    定义文字样式-插件
    获取当前url并指定url中的字符 效果
  • 原文地址:https://www.cnblogs.com/holoyong/p/7243959.html
Copyright © 2020-2023  润新知