数据结构常用树的基本总结

本文总结了树这种重要数据结构的基础知识,包括树的定义、基本术语如根、子树、结点度等,以及各种类型的树如二叉树、满二叉树、完全二叉树、平衡二叉树、线索二叉树和B树、B+树的特性。
摘要由CSDN通过智能技术生成

树是一种比较常用的数据结构,现在做一个常用树的基本总结:

树的基本概念

1)树(Tree)的概念:树是一种递归定义的数据结构,是一种重要的非线性数据结构。树可以是一棵空树,它没有任何的结点;也可以是一棵非空树,至少含有一个结点。

2)根(Root):有且仅有一个结点的非空树,那个结点就是根。

3)子树(Subtree):在一棵非空树中,除根外,其余所有结点可以分为mm≥0)个互不相交的集合。每个集合本身又是一棵树,称为根的子树。

4)结点(Node):表示树中的元素及若干指向其子树的分支。

5)结点的度(Degree):一个结点拥有的子树数目称为该结点的度。

6)叶子结点(Leaf):度为0的结点。

7)孩子(Child):结点子树的根称为该结点的孩子。

8)双亲(Parents):孩子结点的上层结点叫该结点的双亲。

9)兄弟(Sibling):同一双亲的孩子。

10)树的度:一棵树中最大

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、实验目的: 理解二叉特别是完全二叉的性质,掌握二叉的存储结构(二叉链表);熟练掌握二叉常用操作算法(初始化、插入结点、删除结点、遍历等);初步掌握二叉的应用。 二、实验内容: 要求采用二叉链表作为存储结构,完成二叉的建立,前序、中序和后序遍历的操作,求所有叶子及结点总数的操作等。 具体要求如下: ①给出基于二叉链表的二叉类的定义; ②给出二叉初始化(构造函数)的实现; ③给出二叉三种遍历算法的递归实现; ④二叉先序遍历的非递归算法实现; ⑤利用二叉的遍历算法求二叉的结点数、二叉的叶结点数、二叉的高度; ⑥二叉的撤销删除 三、实验步骤: 1、需求分析: 本演示程序用JAVA编写,完成的生成,任意位置的插入、删除,以及遍历二叉中的结点,查找和修改中元素的值。 ① 输入的形式和输入值的范围:插入元素时需要输入插入的位置和元素的值;删除元素时输入删除元素的位置;遍历时采用三种遍历方法中的一种遍历方法;修改操作时需要输入的元素的值;查找操作时,需要找到要查找元素的位置。在所有输入中,元素的值都是整数。 ② 输出的形式:在所有四种操作中都显示操作是否正确以及操作后中的内容。其中删除操作后显示删除的元素的值,遍历二叉中的元素,查找操作、修改操作后显示修改的值。 ③ 程序所能达到的功能:完成的生成(通过插入操作)、插入、删除、遍历、查找、修改操作。 ④ 测试数据: A. 中已有以50,25,75,12,37,43,30,33,87,93,97为关键字的结点 B. 插入操作中依次输入10,20,30,40,50,60,70,80,90,100十个数 C. 删除操作中输入10删除值为10的元素 D. 查找操作中输入20,30,40,50返回这个元素在中的位置 2.概要设计: 1)为了实现上述程序功能,需要定义的抽象数据类型: public int iData; public double dData; public Node leftChild; public Node rightChild; private Node root;int value; private Node getSuccessor; 基本操作:{ Tree () 操作结果:构造一个空的二叉 insert () 初始条件:是否存在一个空二叉 操作结果:往二叉中插入数值 delete () 初始条件:存在一非空的二叉 操作条件:将二叉中的元素删除 displayTree () 初始条件:存在一非空的 操作条件:显示非空中的所有元素的值 getString () 初始条件:存在一非空的二叉 操作结果:返回整个字符串的数值 getChar () 初始条件:存在一非空的二叉 操作结果:返回字符型的数值 getInt () 初始条件:存在一非空的二叉 操作结果:返回整型的数值 find () 初始条件:存在一非空二叉 操作结果:从二叉中查找某一元素 traverse () 初始条件:存在一非空的二叉 操作结果:对二叉中的元素进行遍历 preorder () 初始条件:存在一非空的二叉 操作结果:对二叉中的元素进行先根遍历 inOrder () 初始条件:存在一非空的二叉 操作结果:对二叉中的元素进行中根遍历 postOrder () 初始条件:存在一非空的二叉 操作结果:对二叉中的元素进行后根遍历 DisplayNode () 初始条件:存在一非空的二叉 操作结果:显示出二叉中的整形数值和双精度浮点型数值 public static void main 操作结果:调用主函数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值