数据结构之二叉树的结构和遍历的实现

简介: 数据结构之二叉树的结构和遍历的实现

数据结构之二叉树的结构和遍历的实现

1.二叉树的存储结构

二叉树一般分为两种存储结构,一种是顺序结构,一种是链表结构。

  1. 顺序结构

顺序结构存储就是使用数组来存储,一般使用数组只适合表示完全二叉树,因为不是完全二叉树会有空 间的浪费。而现实中使用中只有堆才会使用数组来存储。二叉树顺 序存储在物理上是一个数组,在逻辑上是一颗二叉树。(非完全二叉树很浪费空间!)

  1. 链式存储

二叉树的链式存储结构是指,用链表来表示一棵二叉树,即用链来指示元素的逻辑关系。 通常的方法是链表中每个结点由三个域组成,数据域和左右指针域,左右指针分别用来给出该结点左孩子和右孩子所 在的链结点的存储地址 。链式结构又分为二叉链和三叉链。

//代码展示

//二叉链

typedefintBTDateType;

 

typedefstructBinaryTreeNode

{

    BTDateTypedate;

    structBinaryTreeNode*left;//指向左孩子

    structBinartTreeNode*right;//指向右孩子

}BTNode;

//三叉链

typedefstructBinaryTreeNode

{

    BTDateTypedate; //指向该节点的数据

    structBinaryTreeNode*parent;//指向该节点的双亲

    structBinaryTreeNode*left;//指向左孩子

    structBinaryTreeNode*right;//指向右孩子

}BTNode;

2.二叉树的遍历

学习二叉树结构,最简单的方式就是遍历。所谓二叉树遍历(Traversal)是按照某种特定的规则,依次对二叉 树中的节点进行相应的操作,并且每个节点只操作一次。访问结点所做的操作依赖于具体的应用问题。 遍历 是二叉树上最重要的运算之一,也是二叉树上进行其它运算的基础。

二叉树的三大遍历

  1. 前序遍历前序遍历(Preorder Traversal 亦称先序遍历)——访问根结点的操作发生在遍历其左右子树之前。
  2. 中序遍历(Inorder Traversal)——访问根结点的操作发生在遍历其左右子树之中(间)。
  3. 后序遍历(Postorder Traversal)——访问根结点的操作发生在遍历其左右子树之后。

所以N(Node)、L(Left subtree)和R(Right subtree)又可解释为 根、根的左子树和根的右子树。NLR、LNR和LRN分别又称为先根遍历、中根遍历和后根遍历。

前序遍历:

typedefintBTDateType;

typedefstructBinaryTreeNode

{

    BTDateTypedate;

    structBinaryTreeNode*left;

    structBinartTreeNode*right;

}BTNode;

 

voidPreOrder(BTNode*root)

{

   if(root==NULL)

   {

       printf("NULL ");

       return;      

   }

   printf("%d ",root->date);//先访问根

   PreOrder(root->left);//再访问左子树

   PreOrder(root->right);//最后访问右子树  

}

前序遍历流程图

Quicker_20230325_144143.png

  • 前序遍历的特点是第一个一定是根!

中序遍历

typedefintBTDateType;

typedefstructBinaryTreeNode

{

    BTDateTypedate;

    structBinaryTreeNode*left;

    structBinartTreeNode*right;

}BTNode;

 

voidInOrder(BTNode*root)

{

   if (root==NULL)

   {

       printf("NULL ");

       return;

   }

   PreOrder(root->left);//先访问左子树

   printf("%d ", root->date);//再访问根

   PreOrder(root->right);//最后访问右子树  

}

  • 中序遍历的特点是知道根的位置就可以判断出左右子树!

后序遍历

typedefintBTDateType;

typedefstructBinaryTreeNode

{

    BTDateTypedate;

    structBinaryTreeNode*left;

    structBinartTreeNode*right;

}BTNode;

 

voidPostOrder(BTNode*root)

{

   if (root==NULL)

   {

       printf("NULL ");

       return;

   }

   PreOrder(root->left);//先访问左子树

   PreOrder(root->right);//然后访问右子树  

   printf("%d ", root->date);//最后访问根

}

 

相关文章
|
22小时前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
1月前
|
机器学习/深度学习 存储 算法
数据结构实验之二叉树实验基础
本实验旨在掌握二叉树的基本特性和遍历算法,包括先序、中序、后序的递归与非递归遍历方法。通过编程实践,加深对二叉树结构的理解,学习如何计算二叉树的深度、叶子节点数等属性。实验内容涉及创建二叉树、实现各种遍历算法及求解特定节点数量。
85 4
|
1月前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
88 16
|
1月前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
132 8
|
2月前
|
存储 算法 关系型数据库
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
这篇文章主要介绍了多路查找树的基本概念,包括二叉树的局限性、多叉树的优化、B树及其变体(如2-3树、B+树、B*树)的特点和应用,旨在帮助读者理解这些数据结构在文件系统和数据库系统中的重要性和效率。
32 0
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
|
2月前
|
存储 算法 搜索推荐
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
这篇文章主要介绍了顺序存储二叉树和线索化二叉树的概念、特点、实现方式以及应用场景。
37 0
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
|
2月前
|
Java
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(二)
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(二)
33 1
|
2月前
|
存储 算法
探索数据结构:分支的世界之二叉树与堆
探索数据结构:分支的世界之二叉树与堆
|
2月前
探索顺序结构:栈的实现方式
探索顺序结构:栈的实现方式
|
2月前
|
存储 算法
数据结构与算法学习十六:树的知识、二叉树、二叉树的遍历(前序、中序、后序、层次)、二叉树的查找(前序、中序、后序、层次)、二叉树的删除
这篇文章主要介绍了树和二叉树的基础知识,包括树的存储方式、二叉树的定义、遍历方法(前序、中序、后序、层次遍历),以及二叉树的查找和删除操作。
34 0