二叉树可视化

二叉树可视化

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

运行演示

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

代码和程序已上传

二叉树可视化程序和代码

二叉树知识

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

平衡二叉树

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

红黑树

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

最优二叉搜索树

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

哈夫曼树

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

KD树

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

B树和B+树

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

参考

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

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

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

相关文章

腾讯面试题

目录 1 tcp可靠性,然后问十六位校验和怎么实现的 2 TCP粘包 3 进程协程线程 4 跳表怎么实现 5 gostruct能不能比较? 6 godefer(fordefer) 7 go select可以用于什么? 8 client如何实现长连接? 1. …

uniapp本地存储的几种方式localStorage

在uniapp开发中,本地存储是一个常见的需求。本地存储可以帮助我们在客户端保存和管理数据,以便在应用程序中进行持久化存储。本文将介绍uniapp中本地存储的几种方式,以及相关的代码示例。 介绍 在移动应用开发中,我们经常需要将…

Camille-学习笔记-SQL语法与数据库

# 数据库的基本概念 * 数据库简介 * 数据库分类 * 常用数据库简介 * 使用场景 * 数据库(DataBase) 就是一个以某种有组织的方式存储的数据集合 * 是存储和管理数据的仓库 * 其本质是一个文件系统 * 数据库管理系统(DBMS)是一款管理软件 ## 数据库分类 *…

红日三打靶!!!

红日三,黑盒测试 环境搭建一.外网打点1.网段探测2.端口服务扫描3.目录扫描4.网站漏洞扫描5.汇总,找破绽6.登陆MySQL改密码 7.进入后台,找能写马的地方8.蚁剑连接9.disable_functions绕过1.蚁剑插件绕过2.bypass_disablefunc_via_LD_PRELOAD绕…

Django模型(四)

一、数据操作初始化 from django.db import models# Create your models here. class Place(models.Model):"""位置信息"""name = models.CharField(max_length=32,verbose_name=地名)address = models.CharField(max_length=64,null=True,verbo…

利用OpenCV实现物流与生产线自动化的革命性突破

背景介绍: 在当今高度自动化的时代,物流和生产线上的每一个环节都关乎企业的核心竞争力。传统的生产方式往往依赖于人工检测和操作,这不仅效率低下,而且容易出错。为了解决这一问题,越来越多的企业开始寻求利用计算机视…

【高阶数据结构】红黑树

文章目录 前言什么是红黑树红黑树的性质红黑树结点的定义红黑树的插入情况一情况二情况三插入代码总结 验证是否为红黑树红黑树的删除 前言 前面我们学习了 AVL 树——高度平衡的二叉搜索树,AVL 树保证了结点的左右子树的高度差的绝对值不超过 1,也就是…

【正点原子STM32】STM32时钟系统(时钟树、时钟源、分频器和倍频系数、锁相环、STM32CubeMX时钟树、系统时钟配置步骤)

一、认识时钟树 1.1、什么是时钟?1.2、认识时钟树(F1)1.3、认识时钟树(F4)1.4、认识时钟树(F7)1.5、认识时钟树(H7) 二、配置系统时钟 2.1、系统时钟配置步骤2.2、外设…

绝世唐门:霍挂六个十万年魂环,一穿七灭团再现,淘汰赛顺利晋级

Hello,小伙伴们,我是拾荒君。 国漫《斗罗大陆2绝世唐门》第32期超前爆料,霍雨浩开局便释放六个十万年魂环,以绝对的气场碾压天灵学院代表队。首次参与高级魂师大赛,霍雨浩便大放异彩秀出超级霍挂,此等操作就连当初的唐…

LeetCode每日一题 | 1690. 石子游戏 VII

文章目录 题目描述问题分析程序代码 题目描述 原题链接 石子游戏中,爱丽丝和鲍勃轮流进行自己的回合,爱丽丝先开始 。 有 n 块石子排成一排。每个玩家的回合中,可以从行中 移除 最左边的石头或最右边的石头,并获得与该行中剩余石…

6-3 C. DS二叉树——二叉树之父子结点

题目描述 给定一颗二叉树的逻辑结构如下图,(先序遍历的结果,空树用字符‘0’表示,例如AB0C00D00),建立该二叉树的二叉链式存储结构。 编写程序输出该树的所有叶子结点和它们的父亲结点 输入 第一行输入一个…

【Soc级系统防御】基于IP的SoC设计中的安全问题

文章目录 Perface硬件知识产权(IP)基于 IP 的 SoC 设计中的安全问题硬件木马攻击攻击模式知识产权盗版和过度生产攻击模式逆向工程集成电路逆向工程示例Fpga 的安全问题FPGA 预演基于 FPGA 的系统的生命周期实体生命周期对 FPGA 比特流的攻击

如何修复鼠标不工作的问题?这里提供几个方法

如果你的鼠标无法连接到你的电脑,或者只能间歇性工作,那就是一个问题。你需要买一个新的吗?不一定。虽然换个便宜的无线鼠标很容易,但在你花钱买一款符合人体工程学的新鼠标或游戏鼠标之前,有一些事情需要尝试。 检查电源 像任何其他外设一样,鼠标需要电源。许多鼠标上都…

人口增长问题 T1063

#include<bits/stdc.h> using namespace std; int main(){int n;double x;cin>>x>>n;for(int i1;i<n;i){xx*1.001;}printf("%.4lf",x);return 0; }

【lesson35】基础IO之fd周边问题

文章目录 基础IO要讲的知识点介绍fd周边问题 基础IO要讲的知识点介绍 1.复习一下C语言的接口 2.直接使用系统接口 3.分析系统接口的细节&#xff0c;引入fd&#xff08;文件描述符&#xff09; 4.fd的周边问题&#xff08;fd的理解、fd和file的关系、fd分配规则、fd重定向…&a…

【数据结构】并查集(路径压缩)

文章目录 并查集1.朴素版本2.路径压缩3.按秩合并4.启发式合并5.练习题 并查集 1.朴素版本 1. 并查集解决的是连通块的问题&#xff0c;常见操作有&#xff0c;判断两个元素是否在同一个连通块当中&#xff0c;两个非同一连通块的元素合并到一个连通块当中。 并查集和堆的结构…

Unity 图片不改变比例适配屏幕

Unity 图片不改变比例适配屏幕 前言项目场景布置代码编写添加并设置脚本效果 前言 遇到一个要让图片适应相机大小&#xff0c;填满屏幕&#xff0c;但不改变图片比例的需求&#xff0c;记录一下。 项目 场景布置 代码编写 创建AdaptiveImageBackground脚本 using System.C…

ConcurrentModificationException异常原因,解决方法,线程安全的单例模式

异常简介 ConcurrentModificationException&#xff08;并发修改异常&#xff09;是基于java集合中的 快速失败&#xff08;fail-fast&#xff09; 机制产生的&#xff0c;在使用迭代器遍历一个集合对象时&#xff0c;如果遍历过程中对集合对象的内容进行了增删改&#xff0c;…

Fink CDC数据同步(二)MySQL数据同步

1 开启binlog日志 2 数据准备 use bigdata; drop table if exists user;CREATE TABLE user(id INTEGER NOT NULL AUTO_INCREMENT,name VARCHAR(20) NOT NULL DEFAULT ,birth VARCHAR(20) NOT NULL DEFAULT ,gender VARCHAR(10) NOT NULL DEFAULT ,PRIMARY KEY(id) ); ALTER TA…

刘知远团队大模型技术与交叉应用L6-基于大模型文本理解和生成介绍

介绍 NLP的下游运用可以分为&#xff1a;NLU(理解)和NLG(生成) 信息检索&#xff1a;NLU 文本生成&#xff1a;NLG 机器问答&#xff1a;NLUNLG 大模型在信息检索 大模型在机器问答 大模型在文本生成 信息检索-Information Retrieval (IR) 背景 谷歌搜索引擎目前同时集成了…