二叉树可视化

news2024/11/15 8:51:42

二叉树可视化

    • 运行演示
    • 代码和程序已上传
    • 二叉树知识
      • 平衡二叉树
      • 红黑树
      • 最优二叉搜索树
      • 哈夫曼树
      • KD树
      • B树和B+树
    • 参考

运行演示

学习二叉树总是脑补图像,实在是恶心,就想写一个能可视化的二叉树,结果没控制好,功能越想越多,先整一个半成品吧,最起码能建立二叉树了。
功能包括创建随机二叉树,输入序列二叉树,前中序生成二叉树,二叉树平衡化,30多个结点表现还凑合,结点多了就难看了,毕竟指数增加。
红黑树还没搞清楚,手撕红黑树真的是烧脑,等整清楚了再来添加!~
在这里插入图片描述

代码和程序已上传

二叉树可视化程序和代码

二叉树知识

这个东西就是排序树,也叫搜索树,排序和搜索有时候混着用,一会儿叫搜索树一会儿叫排序树,挺坑爹的。看应用关注是排序还是搜索。

平衡二叉树

平衡二叉树是左右孩子高度差不大于1,这种树关注查找,通过牺牲插入和删除的效率让数据足够扁平,达到对数级别的性能。

红黑树

红黑树属于泛化的平衡二叉树,左右孩子高度差没有平衡二叉树严格,但是也有限制。没撕清楚。主要应用的也是搜索,可以说是平衡二叉树的实现。关注查找数据。STL的Map是利用红黑树实现的,这个也是道听途说,到底是不是还得翻代码确认。

最优二叉搜索树

最优二叉搜索树和哈夫曼树是静态数据分析建树。树建好以后改动少。带有统计意味,各种和概率挂钩。这个和哈夫曼树有点区别是需要考虑查找失败的情形。

哈夫曼树

和哈夫曼编码拉扯。应用也是静态数据,统计数据概率后编码一下。两端通信时想办法把编码树同步到对端。则发送的信息就可解码读取了,也可以算是一种加密方式。

KD树

多维数据划分,搜资料想到信息如果按照kd组织的话可以查找范围内数据。是不是比距离判定好些,也需要验证。

B树和B+树

数据库用到的多些,B树主要是构建目录,B+树数据存储在叶子节点。一个需要注意的是数据库存储都是在磁盘里面的,不是内存数据,从磁盘倒腾到内容代价太大,所以通过分页建立目录定位准确后一片一片的加载到内存来使用数据。

参考

数据结构
算法设计与分析
数据库系统

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1429922.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第2集《忏悔法门》

请大家打开讲义第五面, 这一科讲到甲二,正式说明忏悔的方法。「忏悔的方法」有三个主题,第一个是「思惟业果的道理」,这当中有「理论的思惟」,跟「事相的观察」。 理论的思惟是说:今天当我们造了一个业&a…

asp.net core通过读取配置文件来动态生成接口

如果希望接口是每次通过配置文件生成的,这样设计一些低代码的方式来获得接口。 系统目录结构: 启动配置代码: using Microsoft.AspNetCore.Hosting; using System.Configuration; using System.Data.Entity; using Swashbuckle.AspNetCore.…

线性代数:线性方程组

目录 一、线性方程组概念 二、消元法求线性方程组 三、系数阵的秩与线性方程组的解 无解 唯一解 无数解 相关定理 一、线性方程组概念 二、消元法求线性方程组 三、系数阵的秩与线性方程组的解 无解 唯一解 无数解 相关定理

stack_queue:三个关键注意事项解析

一、stack与容器 template<class T, class Container> class stack { private:Container _con; };Container 为容器&#xff0c;在实例化创建对象时&#xff0c;我们可以传 vector<T> 或 list<T> 等作为栈的底层。 举例&#xff1a; int main() {stack<i…

自动化诊断测试之CANoe.DIVA入门

目录 0 前言 1 CANoe.DIVA基础 2 CANoe.DIVA TIPs 0 前言 写在前面&#xff1a;如对本文有任何疑问欢迎评论区讨论&#xff0c;希望和大家一起进步。同时HIL测试群欢迎大家加入如有需要也可私信我拉你。VT和DIVA都可以做UDS的自动化测试&#xff0c;但相对VT来说使用DIVA生成…

Python中的变量命名规则

Python 变量命名规则 1. 要具有描述性 2.变量名只能是&#xff1a;数字&#xff0c;字母组成&#xff0c;不可以是空格或特殊字符&#xff0c;如&#xff1a;(#&#xff1f;。&#xff0c;&#xffe5;$*~!&)等 3.不能是中文 4.不能以数字开头 5.保留字符是不能被使用…

从MySQL到TiDB:兼容性全解析

MySQL 在高并发和大数据量场景下&#xff0c;单个实例的扩展性有限。而 TiDB 作为一款分布式NewSQL数据库&#xff0c;设计之初就支持水平扩展&#xff08;Scale-Out&#xff09;&#xff0c;通过增加节点来线性提升处理能力和存储容量&#xff0c;能够很好地应对大规模数据和高…

pdmodel从动态模型转成静态onnx

1.下载项目 git clone https://github.com/jiangjiajun/PaddleUtils.git 2.新建两个新的文件夹 第一个文件夹放两个必要文件 第二个文件夹可以设置为空&#xff0c;用来存放转换后的模型 如图&#xff1a; 3.在终端运行 python paddle/paddle_infer_shape.py --model_dir …

应对手机数据丢失的5大安卓数据恢复软件

我们都去过那里。您的手机上的数据丢失了&#xff0c;现在无法恢复。这尤其令人恐惧&#xff0c;因为我们的手机上都有如此多的信息。从图片、应用程序、个人信息&#xff0c;甚至是来自可能已不复存在的亲人的短信和语音邮件。这种情况确实发生了&#xff0c;而且也不仅仅是An…

C系列-柔性数组

&#x1f308;个人主页: 会编程的果子君 ​&#x1f4ab;个人格言:“成为自己未来的主人~” 目录 ​编辑 柔性数组 柔性数组的特点 柔性数组的使用 柔性数组的优势 柔性数组 也许你从来没有听说过柔性数组这个概念&#xff0c;但是它确实是存在的&#xff0c;C99中&#…

AJAX-常用请求方法和数据提交

常用请求方法 请求方法&#xff1a;对服务器资源&#xff0c;要执行的操作 axios请求配置 url&#xff1a;请求的URL网址 method&#xff1a;请求的方法&#xff0c;如果是GET可以省略&#xff1b;不用区分大小写 data&#xff1a;提交数据 axios({url:目标资源地址,method…

【第二十二课】最短路:多源最短路floyd算法(acwing-852 spfa判断是否存在负环 / acwing-854 / c++代码)

目录 acwing-852 代码如下 一些解释 acwing-854 foyld算法思想 代码如下 一些解释 acwing-852 在spfa求最短路的算法基础上进行修改。 代码如下 #include<iostream> #include<cstring> #include<algorithm> #include<queue> using names…

Unity animator 动画实现指定时间开始播放

在我们使用Unity帧动画时&#xff0c;如用到同一个帧动画的部分动画&#xff0c;那么我们可以考虑用指定播放时间的方法实现。 如我在场景中创建一个2D帧动画&#xff0c;并创建一个2D对象使用该帧动画。 然后复制该2D对象&#xff0c;并创建一个控制脚本GameController1.cs&a…

[每周一更]-(第86期):NLP-实战操作-文本分类

NLP文本分类的应用场景 医疗领域 - 病历自动摘要&#xff1a; 应用&#xff1a; 利用NLP技术从医疗文档中自动生成病历摘要&#xff0c;以帮助医生更快速地了解患者的状况。 法律领域 - 法律文件分类&#xff1a; 应用&#xff1a; 使用文本分类技术自动分类法律文件&#xf…

2024美赛数学建模C题思路+代码

文章目录 1 赛题思路2 美赛比赛日期和时间3 赛题类型4 美赛常见数模问题5 建模资料 1 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 2 美赛比赛日期和时间 比赛开始时间&#xff1a;北京时间2024年2月2日&#xff08;周五&#xff…

2024年数学建模美赛 A~E 题目解析

2024美赛A题&#xff1a;资源可用性和性别比例 背景 尽管一些动物物种不属于通常的雄性或雌性&#xff0c;大多数物种在出生时要么显著地为雄性&#xff0c;要么为雌性。虽然许多物种在出生时表现出1:1的性别比&#xff0c;但其他物种则偏离了这个均衡的性别比例。这被称为性…

MySQL 小技巧:恢复误删除的表

案例说明 每天 2:30 做完全备份&#xff0c;早上 10:00 误删除 了表 students&#xff0c;10:10 才发现故障 现需要将数据库还原到 10:10 的状态&#xff0c;且恢复被删除的 students 表。 思路分析 停止数据库服务将数据 还原到 2:30 的完全备份状态再通过二进制日志还原 默…

羊大师:冬季出行,心血管病患者应做好哪些准备?

羊大师&#xff1a;冬季出行&#xff0c;心血管病患者应做好哪些准备&#xff1f; 冬季将至&#xff0c;气温骤降&#xff0c;寒冷的天气不仅让人感到不适&#xff0c;对于患有心血管病的人来说&#xff0c;更是需要格外注意。在这个寒冷的季节里&#xff0c;心血管病患者需要…

今日arXiv最热NLP大模型论文:IBM研究院提出Genie方法,自动生成高质量数据集

数据是大模型的基石。但传统的数据集创建方法通常依赖人工&#xff0c;耗时耗力成本高&#xff0c;另外数据集的来源复杂&#xff0c;噪声大&#xff0c;比如新闻媒体稿或者社交媒体&#xff0c;数据质量难以保证。为此&#xff0c;IBM研究院了一种名为Genie的新方法&#xff0…

Android搭建python环境

通过wifi连接adb&#xff1a; 首先下载无线abd工具&#xff1a; https://www.downkuai.com/android/170494.html 运行效果图&#xff1a; 然后开启后根据自身ip即可连接&#xff1a; adb connect ip:5555 安装busybox: 首先执行如下命令查看手机架构&#xff1a; adb sh…