栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【浅谈数据结构】树、二叉树基本概念

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【浅谈数据结构】树、二叉树基本概念

文章目录

初识二叉树

1)树的概念及结构

1.1 树的定义1.2 树的相关概念1.3 树的表示(左孩子右兄弟表示法) 2)二叉树概念及结构

2.1 概念:度最大为二的树2.2 二叉树的不同状态2.3 满二叉树2.4 完全二叉树2.5 二叉树的性质

初识二叉树 1)树的概念及结构

定义: 任何一棵树都会被分为 根和子树(或者是空树)

Ps:树型结构中,子集之间不可以有任何交集 , 否则就不是树形结构

1.1 树的定义

(图来源于百度百科树(数据结构名词)_百度百科 (baidu.com))

1.2 树的相关概念

节点的度:一个节点含有的子树的个数称为该节点的度; 如上图:A的为6
叶节点或终端节点:度为0的节点称为叶节点; 如上图:B、C、H、I…等节点为叶节点
非终端节点或分支节点:度不为0的节点; 如上图:D、E、F、G…等节点为分支节点
双亲节点或父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点; 如上图:A是B的父节点
孩子节点或子节点:一个节点含有的子树的根节点称为该节点的子节点; 如上图:B是A的孩子节点
兄弟节点:具有相同父节点的节点互称为兄弟节点; 如上图:B、C是兄弟节点
树的度:一棵树中,最大的节点的度称为树的度; 如上图:树的度为6
节点的层次:从根开始定义起,根为第1层,根的子节点为第2层,以此类推;
树的高度或深度:树中节点的最大层次; 如上图:树的高度为4
堂兄弟节点:双亲在同一层的节点互为堂兄弟;如上图:H、I互为兄弟节点
节点的祖先:从根到该节点所经分支上的所有节点;如上图:A是所有节点的祖先
子孙:以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是A的子孙

森林:由m(m>0)棵互不相交的树的集合称为森林 (并查集中有体现)

1.3 树的表示(左孩子右兄弟表示法)
typedef int DataType;
struct Node
{
struct Node* _FirstChild1;  // 指向 第一个 孩子结点
struct Node* _pNextBrother; // 指向其 下一个 兄弟结点
DataType _data; 			// 结点中的 数据域
};

2)二叉树概念及结构 2.1 概念:度最大为二的树

Ps:

    二叉树不存在度大于2的结点二叉树的子树有左右之分,次序不能颠倒,因此二叉树是有序树
2.2 二叉树的不同状态

2.3 满二叉树

定义:除最后一层无任何子节点外,每一层上的所有结点都有两个子结点的二叉树。

Ps:

    所有的叶子结点都在最后一层

    所有的分支节点都有两个孩子

2.4 完全二叉树

定义:一棵深度为k的有n个结点的二叉树,对树中的结点按从上至下、从左到右的顺序进行编号,如果编号为i(1≤i≤n)的结点与 满二叉树 中编号为i的结点在二叉树中的位置相同,则这棵二叉树称为完全二叉树。

Ps:

    前 N-1 层都是满的最后一层不满 但是最后一层从左到右是连续的最多只有一个 度为 1 的 节点
2.5 二叉树的性质

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/726558.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号