数据结构--树

embedded/2024/9/24 9:20:51/

文章目录

    • 1. 的理解
    • 2. 二叉的基本概念
    • 3. 二叉的遍历
    • 4. 经典二叉
    • 5. 二叉及其结点的表示

1. 的理解

在这里插入图片描述

专有名词解释:

结点中的数据元素都称之为结点

根节点:最上面的结点称之为根,一颗只有一个根且由根发展而来,从另外一个角度来说,每个结点都可以认为是其子的根

父节点:结点的上层结点,如图中,结点K的父节点是E、结点L的父节点是G

子节点:节点的下层结点,如图中,节点E的子节点是K节点、节点G的子节点是L节点

兄弟节点:具有相同父节点的结点称为兄弟节点,图中F、G、H互为兄弟节点

结点的度数:每个结点所拥有的子的个数称之为结点的度,如结点B的度为3

:度数为0的结点,也叫作终端结点,图中D、K、F、L、H、I、J都是

非终端节点(或分支节点)叶以外的节点,或度数不为0的节点。图中根、A、B、C、E、G都是

的深度(或高度)中结点的最大层次数,图中的深度为4

结点的层数:从根节点到中某结点所经路径上的分支称为该结点的层数,根节点的层数规定为1,其余结点的层数等于其父亲结点的层数+1

同代:在同一棵中具有相同层数的节点

2. 二叉的基本概念

二叉(Binary tree)是形结构的一个重要类型。二叉特点是每个结点最多只能有两棵子,且有左右之分。许多实际问题抽象出来的数据结构往往是二叉形式,二叉的存储结构及其算法都较为简单,因此二叉显得特别重要。

3. 二叉的遍历

  • 前序遍历:中左右(根左右)

    即先访问根结点,再前序遍历左子,最后再前序遍历右子 。前序遍历运算访问二叉各结点是以根、左、右的顺序进行访问的。

    在这里插入图片描述

    前序遍历:ABDEGCFHI

public class TreeSearch {// 创建一个二叉public TreeNode getTargetTree() {// 叶子节点TreeNode G = new TreeNode("G");TreeNode D = new TreeNode("D");TreeNode E = new TreeNode("E", G, null);TreeNode B = new TreeNode("B", D, E);TreeNode H = new TreeNode("H");TreeNode I = new TreeNode("I");TreeNode F = new TreeNode("F", H, I);TreeNode C = new TreeNode("C", null, F);// 构造根节点TreeNode root = new TreeNode("A", B, C);return root;}/*** 前序遍历*/public void preorderVistTreeNode(TreeNode node) {if (null != node) {System.out.print(node.value);if (null != node.leftchildren) {preorderVistTreeNode(node.leftchildren);}if (null != node.rightchildre) {preorderVistTreeNode(node.rightchildre);}}}public static void main(String[] args) {TreeSearch treeSearch = new TreeSearch();TreeNode tree = treeSearch.getTargetTree();System.out.print("前序遍历:");treeSearch.preorderVistTreeNode(tree);System.out.println("");		}
}
  • 中序遍历:左中右(左根右)

    即先中前序遍历左子,然后再访问根结点,最后再中序遍 历右子。中序遍历运算访问二叉各结点是以左、根、右的顺序进行访问的。

    在这里插入图片描述

    中序遍历:DBGEACHFI

/**
*  中序遍历
*/
public void inorderVistTreeNode(TreeNode node){if(null != node){if(null != node.leftchildren){inorderVistTreeNode(node.leftchildren);}System.out.print(node.value);if(null != node.rightchildre){inorderVistTreeNode(node.rightchildre);}}
}public static void main(String[] args) {TreeSearch treeSearch = new TreeSearch();TreeNode tree= treeSearch.getTargetTree();System.out.print("中序遍历:");treeSearch.inorderVistTreeNode(tree);System.out.println("");
}
  • 后序遍历:左右中(左右根)

    即先后序遍历左子,然后再后序遍历右子,最后访问根 结点。后序遍历运算访问二叉各结点是以左、右、根的顺序进行访问的。

    在这里插入图片描述

    后序遍历:DGEBHIFCA

/***  后序遍历*/
public void postorderVistTreeNode(TreeNode node){if(null != node){if(null != node.leftchildren){postorderVistTreeNode(node.leftchildren);}if(null != node.rightchildre){postorderVistTreeNode(node.rightchildre);}System.out.print(node.value);}
}public static void main(String[] args) {TreeSearch treeSearch = new TreeSearch();TreeNode tree= treeSearch.getTargetTree();System.out.print("后序遍历:");treeSearch.postorderVistTreeNode(tree);System.out.println("");
}

4. 经典二叉

1、满二叉: 除最后一层无任何子节点外,每一层上的所有结点都有两个子结点的二叉。 第n层的结点数是2的n-1次方,总的结点个数是2的n次方-1

在这里插入图片描述

2、完全二叉: 叶结点只能出现在最底层的两层,且最底层叶结点均处于次底层叶结点的左侧。

在这里插入图片描述
3、二叉排序/查找/搜索:即为BST (binary search/sort tree)。满足如下性质:
(1)若它的左子不为空,则左子上所有结点的值均小于它的根节点的值;
(2)若它的右子上所有结点的值均大于它的根节点的值;
(3)它的左、右子也分别为二叉排序/查找/搜索

对二叉查找进行中序遍历,得到有序集合。便于检索。

4、平衡二叉:(Self-balancing binary search tree,AVL)首先是二叉排序,此外具有以下性质:
(1)它是一棵空或它的左右两个子的高度差的绝对值不超过1
(2)并且左右两个子也都是一棵平衡二叉
(3)不要求非叶节点都有两个子结点

平衡二叉的目的是为了减少二叉查找的层次,提高查找速度。平衡二叉的常用实现有红黑、AVL、替罪羊、Treap、伸展等。

5、红黑:即Red-Black Tree。红黑的每个节点上都有存储位表示节点的颜色,可以是红(Red)或黑(Black)。

红黑是一种自平衡二叉查找,是在计算机科学中用到的一种数据结构,它是在 1972 年由 Rudolf Bayer 发明的。红黑是复杂的,但它的操作有着良好的最坏情况运行时间,并且在实践中是高效的:它可以在 O(log n)时间内做查找,插入和删除, 这里的 n 是中元素的数目。

红黑的特性:

  • 每个节点是红色或者黑色

  • 根节点是黑色

  • 每个叶子节点(NIL)是黑色。(注意:这里叶子节点,是指为空(NIL或NULL)的叶子节点)

  • 每个红色节点的两个子节点都是黑色的。(从每个叶子到根的所有路径上不能有两个连续的红色节点)

  • 从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点(确保没有一条路径会比其他路径长出2倍)

当我们插入或删除节点时,可能会破坏已有的红黑,使得它不满足以上5个要求,那么此时就需要进行处理,使得它继续满足以上的5个要求:

1、recolor :将某个节点变红或变黑

2、rotation :将红黑某些结点分支进行旋转(左旋或右旋)

红黑可以通过红色节点和黑色节点尽可能的保证二叉的平衡。主要是用它来存储有序的数据,它的时间复杂度是O(logN),效率非常之高。

5. 二叉及其结点的表示

普通二叉

public class BinaryTree<E>{private TreeNode root; //二叉的根结点private int total;//结点总个数private class TreeNode{//至少有以下几个部分TreeNode parent;TreeNode left;E data;TreeNode right;public TreeNode(TreeNode parent, TreeNode left, E data, TreeNode right) {this.parent = parent;this.left = left;this.data = data;this.right = right;}}
}

TreeMap红黑

public class TreeMap<K,V> {private transient Entry<K,V> root;private transient int size = 0;static final class Entry<K,V> implements Map.Entry<K,V> {K key;V value;Entry<K,V> left;Entry<K,V> right;Entry<K,V> parent;boolean color = BLACK;/*** Make a new cell with given key, value, and parent, and with* {@code null} child links, and BLACK color.*/Entry(K key, V value, Entry<K,V> parent) {this.key = key;this.value = value;this.parent = parent;}}
}

http://www.ppmy.cn/embedded/116021.html

相关文章

Google 扩展 Chrome 安全和隐私功能

过去一周&#xff0c;谷歌一直在推出新特性和功能&#xff0c;旨在让用户在 Chrome 上的桌面体验更加安全&#xff0c;最新的举措是扩展在多个设备上保存密钥的功能。 到目前为止&#xff0c;Chrome 网络用户只能将密钥保存到 Android 上的 Google 密码管理器&#xff0c;然后…

中兴交换机三层配置

中兴交换机三层配置 目的&#xff1a;将1-10端口划分到3001vlan&#xff0c;11-20端口划分到3002vlan中去 客户端客户端IPvlan网关主机A88.88.1.1203001192.168.1.254主机B192.168.100.1303002192.168.100.254 1、通过Console线登录设备 **********************************…

玩转Google SERP API 说明

Google SERP API 对接说明 Google SERP&#xff08;Search Engine Results Page&#xff09;是用户在Google搜索引擎中输入查询后看到的结果页面。它显示自然搜索结果、广告、特色摘要、知识图谱以及图片、视频等多种内容&#xff0c;旨在为用户提供最相关的信息。 本文将详细…

mysql相关知识

查询一条sql语句的流程 连接器:建立连接&#xff0c;管理连接、校验用户身份查询缓存:查询语句如果命中查询缓存则直接返回&#xff0c;否则继续往下执行&#xff08;MSQL8.0 已删除&#xff09;解析 SQL&#xff1a;通过解析器对 SQL 查询语句进行词法分析、语法分析&#xf…

统信服务器操作系统进入【单用户模式】

统信服务器操作系统D版、E版、A版进入单用户模式的方式。 文章目录 前言一、问题现象二、问题原因三、解决方案1. D版问题解决方案2. E版及A版问题解决方案前言 D版又称企业版、E版又称欧拉版、A版又称龙蜥版。 单用户模式主要是在 grub2 引导时编辑内核引导,一般用于修改用…

后端接收数组,集合类数据

文章目录 一. 请求行Path参数&#xff08;不建议&#xff09;二.数组接收&#xff08;不建议&#xff09;三.List集合接收&#xff08;建议&#xff09;四. GET请求既包含请求体又包含请求行 一. 请求行Path参数&#xff08;不建议&#xff09; DeleteMapping("/{ids}&quo…

Pointnet++改进59:全网首发MogaBlock(2024最新模块)|用于在纯基于卷积神经网络的模型中进行判别视觉表示学习,具有良好的复杂性和性能权衡

简介:1.该教程提供大量的首发改进的方式,降低上手难度,多种结构改进,助力寻找创新点!2.本篇文章对Pointnet++特征提取模块进行改进,加入MogaBlock,提升性能。3.专栏持续更新,紧随最新的研究内容。 目录 1.理论介绍 2.修改步骤 2.1 步骤一 2.2 步骤二 2.3 步骤三 1.…

Linux基础3-基础工具4(git),冯诺依曼计算机体系结构

上篇文章&#xff1a;Linux基础3-基础工具3&#xff08;make,makefile,gdb详解&#xff09;-CSDN博客 本章重点&#xff1a; 1. git简易使用 2. 冯诺依曼计算机体系结构介绍 目录 一. git使用 1.1 什么是git? 1.2 git发展史 1.3 git创建仓库 1.4 git命令操作 二. 冯诺依…