Python数据结构之树的全面解读

目录
  • 前言
  • 🧡基本概念
    • 🌳树的定义
    • 🌲基本术语
  • 💚树的逻辑结构
    • 🍉前序遍历
    • 🍓后序遍历
    • 🍒层序遍历
  • 💜树的存储结构
    • 🍀双亲表示法
    • 🍁孩子链表表示法
    • 🍃双亲孩子表示法
    • 🍂孩子兄弟表示法
  • 总结

前言

提示:以下是本篇文章正文内容

🧡基本概念

🌳树的定义

树是n(n≥0)个结点的有限集合,n = 0时,称为空树,这是一种特殊情况

在任意一棵非空树中应满足:
①有且仅有一个特定的称为根的结点
②当n > 1时,其余结点可分为m(m > 0)个互不相交的有限集合T1,T2,…,Tm,其中每个集合本身又是一棵树,并且称为根结点的子树==

∅ 空树——结点数为0的树

非空树的特性:

有且仅有一个根节点
除了根节点外,任何一个结点都有且仅有一个前驱
每个结点可以有0个或多个后继

🌲基本术语

1.度

(1)结点的度:结点所拥有的子树的个数

(2)树的度:树中各结点度的最大值

A的度为3,同时也是树的度,B的度为2

2.叶子节点和分支节点
(1)叶子节点
度为0的节点,也称为终端结点

(2)分支节点
度不为0的节点,也称为非终端结点

在上图中,K,L,M,F,G,I,J均为叶子节点

3.双亲与孩子
(1)祖先结点:对于任何节点n ,它的祖先是位于根到节点n之间的路径上的节点

(2)子孙结点:一个结点含有的子树的根结点的子节点

在树中,如果有一条路径从节点x到节点y,则称x为y的祖先,y为x的子孙

(3)双亲结点(父节点):若一个结点含有子结点,则这个结点称为其子结点的父节点

(4)孩子结点:一个结点含有的子树的根结点称为该结点的子结点

(5)兄弟结点:具有相同父结点的结点互称为兄弟结点

(6)堂兄弟结点:如果树的两个节点深度相同,但父节点不同,则它们是一对堂兄弟节点
B,C,D互为兄弟节点,E,G,I互为堂兄弟节点,B为E,F的父节点,而E,F为B的子节点

(4)树的深度
节点所在层数:根节点的层数为1,对于其他任何节点,若某节点在第K层,则其孩子节点在K+1层

树的深度:树中所有节点的最大层数,也称为高度
在上图中,树的深度为4

(5)树的类型
有序树:树中结点的各子树从左至右是有次序的,不能互换
无序树:树中结点的各子树从左至右是无次序的,可以互换

注:在数据结构中,一般的讨论的一般是有序树

(6)森林
森林是m(m≥0)棵互不相交的树的集合,m可为0,空森林

💚树的逻辑结构

树的遍历:从根节点出发,按照某种次序访问树中所有的节点,使得每个节点被访问一次且仅被访问一次

访问:抽象操作,可以是对节点进行的各种处理,这里简化为输出节点的数据

遍历的实质:树的结构(非线性结构) – > 线性结构

树通常有前序(根)遍历,后序(根)遍历,层序(次)遍历三种

🍉前序遍历

树的前序遍历操作定义为:若树为空,则空操作返回;否则:
(1)先访问根节点
(2)然后按照从左到右的顺序前序遍历根节点的每一颗子树

如图前序遍历序列:A–>B–>D–>E–>H–>I–>F–>C–>G

🍓后序遍历

树的后序遍历操作定义为:若树为空,则空操作返回;否则:
(1)先按照从左到右的顺序后序遍历根节点的每一颗子树
(2)最后访问根节点

如图后序遍历序列:D–>H–>I–>E–>F–>B–>G–>C–A

🍒层序遍历

树的层序遍历操作定义为:从树的第一层(即根节点)开始,自上而下的逐层遍历,在同一层中,按照从左到右的顺序对节点逐个访问

如图层序遍历序列:A–>B–>C–>D–>E–>F–>G–>H–>I

💜树的存储结构

实现树的存储结构,关键在于表示树中的节点之间的关系

🍀双亲表示法

基本思想:用一维数组来存储树的各个节点(一般按层序存储),数组中的一个元素对应树中的一个节点,包括节点的数据信息和节点的双亲在数组中的下标。

节点结构

struct PNode
{
	DataType data; //数据域
	int parent;   //指针域,双亲在数组中的下标
}

树的双亲表示法实质上是一个静态链表
如图所示:

还可以将孩子节点或者兄弟节点的下标也进行存储

🍁孩子链表表示法

将结点的所有孩子放在一起,构成线性表

基本思想:把每个结点的孩子排列起来,看成是一个线性表,且以单链表存储,则n个结点共有n个孩子链表。这n个单链表共有n个头指针,这n个头指针又组成了一个线性表,为了便于进行查找采用顺序存储。最后, 将存放n个头指针的数组和存放n个结点的数组结合起来,构成孩子链表的表头数组

链表中的每个节点包含一个数据域和多个指针域,每个指针域指向该节点的一个孩子节点

方案一:
指针域的个数等于树的深度

缺点:浪费存储空间

方案二:
指针域的个数等于该结点的度

缺点:每个结点结构不一致

孩子节点

struct CTNode
{
	int child;
	CTNode *next; // 指向下一个孩子结点的指针
}

表头结点

struct CBNode
{
	DataType data;
	CTNode *firstChild; // 每个链表的头指针
}

存储结构

🍃双亲孩子表示法

在孩子链表中表头数组添加了节点的双亲结点

🍂孩子兄弟表示法

某节点的第一个孩子是唯一的,某一节点的右兄弟是唯一的,设置两个分别指向该节点的第一个孩子和右兄弟的指针

struct TNode
{
	DataType data;
	TNode *firstChild,*rightSib;
}

总结

提示:这里对文章进行总结:

到此这篇关于Python数据结构之树的全面解读的文章就介绍到这了,更多相关Python 数据结构内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python数据结构之哈夫曼树定义与使用方法示例

    本文实例讲述了Python数据结构之哈夫曼树定义与使用方法.分享给大家供大家参考,具体如下: HaffMan.py #coding=utf-8 #考虑权值的haff曼树查找效率并非最高,但可以用于编码等使用场景下 class TreeNode: def __init__(self,data): self.data=data self.left=None self.right=None self.parent=None class HaffTree: def __init__(self): sel

  • Python数据结构与算法之二叉树结构定义与遍历方法详解

    本文实例讲述了Python数据结构与算法之二叉树结构定义与遍历方法.分享给大家供大家参考,具体如下: 先序遍历,中序遍历,后序遍历 ,区别在于三条核心语句的位置 层序遍历  采用队列的遍历操作第一次访问根,在访问根的左孩子,接着访问根的有孩子,然后下一层 自左向右一一访问同层的结点 # 先序遍历 # 访问结点,遍历左子树,如果左子树为空,则遍历右子树, # 如果右子树为空,则向上走到一个可以向右走的结点,继续该过程 preorder(t): if t: print t.value preorde

  • Python数据结构与算法之字典树实现方法示例

    本文实例讲述了Python数据结构与算法之字典树实现方法.分享给大家供大家参考,具体如下: class TrieTree(): def __init__(self): self.root = {} def addNode(self,str): # 树中每个结点(除根节点),包含到该结点的单词数,以及该结点后面出现字母的键 nowdict = self.root for i in range(len(str)): if str[i] not in nowdict: # 发现新的组合方式 nowdi

  • Python描述数据结构学习之哈夫曼树篇

    前言 本篇章主要介绍哈夫曼树及哈夫曼编码,包括哈夫曼树的一些基本概念.构造.代码实现以及哈夫曼编码,并用Python实现. 1. 基本概念 哈夫曼树(Huffman(Huffman(Huffman Tree)Tree)Tree),又称为最优二叉树,指的是带权路径长度最小的二叉树.树的带权路径常记作: 其中,nnn为树中叶子结点的数目,wkw_kwk​为第kkk个叶子结点的权值,lkl_klk​为第kkk个叶子结点与根结点的路径长度. 带权路径长度是带权结点和根结点之间的路径长度与该结点的权值的乘

  • Python数据结构之二叉排序树的定义、查找、插入、构造、删除

    前言   本篇章主要介绍二叉树的应用之一------二叉排序树,包括二叉排序树的定义.查找.插入.构造.删除及查找效率分析. 1. 二叉排序树的定义   二叉排序树 ( B i n a r y (Binary (Binary S o r t Sort Sort T r e e , B S T ) Tree,BST) Tree,BST),也称为二叉查找树,具有以下性质:   (1) 若左子树非空,则左子树上所有结点的值均小于根结点的值:   (2) 若右子树非空,则右子树上所有结点的值均大于根结点

  • Python数据结构之栈、队列及二叉树定义与用法浅析

    本文实例讲述了Python数据结构之栈.队列及二叉树定义与用法.分享给大家供大家参考,具体如下: 目前只实现了三种,栈.队列和二叉树,哪天得空继续补吧~ 1. 栈 #栈 class Stack: def __init__(self,size = 16): self.stack = [] self.size = size self.top = -1 def setSize(self, size): self.size = size def isEmpty(self): if self.top ==

  • Python数据结构与算法之完全树与最小堆实例

    本文实例讲述了Python数据结构与算法之完全树与最小堆.分享给大家供大家参考,具体如下: # 完全树 最小堆 class CompleteTree(list): def siftdown(self,i): """ 对一颗完全树进行向下调整,传入需要向下调整的节点编号i 当删除了最小的元素后,当新增加一个数被放置到堆顶时, 如果此时不符合最小堆的特性,则需要将这个数向下调整,直到找到合适的位置为止""" n = len(self) # 当 i 节

  • 数据结构之树的概念详解

    数据结构树简介 一.树简介 树(Tree)是一种抽象的数据结构,是一个数据的集合,集合中的数据组成了一个树状结构.例如上图,看起来像一棵倒挂的树,根朝上叶朝下. 树是由n(n>=0)个节点组成的具有层次关系的数据集合.当 n=0 时,树中没有节点,称为空树.当 n>0 时,有且仅有一个节点被称为根节点(Root),如果 n=1 ,树只有根节点一个节点.如果 n>1 ,除根节点外,将其余的节点分成m(m>0)个互不相交的数据集合,这 m 个集合每一个都要满足树的结构(有且仅有一个根节

  • Python 数据结构之树的概念详解

    数据结构树简介 一.树简介 树(Tree)是一种抽象的数据结构,是一个数据的集合,集合中的数据组成了一个树状结构.例如上图,看起来像一棵倒挂的树,根朝上叶朝下. 树是由n(n>=0)个节点组成的具有层次关系的数据集合.当 n=0 时,树中没有节点,称为空树.当 n>0 时,有且仅有一个节点被称为根节点(Root),如果 n=1 ,树只有根节点一个节点.如果 n>1 ,除根节点外,将其余的节点分成m(m>0)个互不相交的数据集合,这 m 个集合每一个都要满足树的结构(有且仅有一个根节

  • python数据结构树和二叉树简介

    一.树的定义 树形结构是一类重要的非线性结构.树形结构是结点之间有分支,并具有层次关系的结构.它非常类似于自然界中的树.树的递归定义:树(Tree)是n(n≥0)个结点的有限集T,T为空时称为空树,否则它满足如下两个条件:(1)有且仅有一个特定的称为根(Root)的结点:(2)其余的结点可分为m(m≥0)个互不相交的子集Tl,T2,-,Tm,其中每个子集本身又是一棵树,并称其为根的子树(Subree). 二.二叉树的定义 二叉树是由n(n≥0)个结点组成的有限集合.每个结点最多有两个子树的有序树

  • Python数据结构树与算法分析

    目录 1.示例 2.术语及定义 3.实现 3.1 列表之列表 3.2节点与引用 4.二叉树的应用 4.1解析树 4.2树的遍历 5.利用二叉堆实现优先级队列 6.二叉搜索树 6.1搜索树的实现 7.平衡二叉搜索树(AVL树) 1.示例 树的一些属性: 层次性:树是按层级构建的,越笼统就越靠近顶部,越具体则越靠近底部. 一个节点的所有子节点都与另一个节点的所有子节点无关. 叶子节点都是独一无二的. 嵌套 2.术语及定义 节点:树的基础部分.节点的名字 → 键,附加信息 → 有效载荷. 边:两个节点

  • Python数据结构与算法(几种排序)小结

    Python数据结构与算法(几种排序) 数据结构与算法(Python) 冒泡排序 冒泡排序(英语:Bubble Sort)是一种简单的排序算法.它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成.这个算法的名字由来是因为越小的元素会经由交换慢慢"浮"到数列的顶端. 冒泡排序算法的运作如下: 比较相邻的元素.如果第一个比第二个大(升序),就交换他们两个. 对每一对相邻元素作同样的工作,从

随机推荐