先序中序后序遍历二叉树_一颗二叉树的先序序列和后序序列正好相反, 该二叉树的形态是什么?...

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 21:01   3484   0

今天我们主要介绍二叉树的遍历算法,在开始正文之前请首先思考一下下面这个问题:

问:若一颗二叉树的先序序列和后序序列正好相反, 该二叉树的形态是什么?

答案:文末揭晓

一二叉树的四种遍历方法

二叉树的遍历是指按照一定次序访问树中所有节点,并且每个节点仅被访问一次的过程。下面我们介绍四种遍历二叉树的方法:

先序遍历

先序遍历二叉树的过程是:

  • 访问根节点;

  • 先序遍历左子树;

  • 先序遍历右子树;

先序遍历的递归算法

void PreOrder(BTNode *b)
{ if (b!=NULL)
{ printf("%c ",b->data); // 访问根节点
PreOrder(b->lchild);
PreOrder(b->rchild);
}
}
中序遍历

中序遍历二叉树的过程是:

  • 中序遍历左子树;

  • 访问根节点;

  • 中序遍历右子树;

中序遍历的递归算法

void InOrder(BTNode *b)
{ if (b!=NULL)
{
InOrder(b->lchild); printf(“%c “,b->data); // 访问根节点
InOrder(b->rchild);
}
}
后序遍历

后序遍历二叉树的过程是:

  • 后序遍历左子树;

  • 后序遍历右子树;

  • 访问根节点。

后序遍历的递归算法

void PostOrder(BTNode *b)
{ if (b!=NULL)
{
PostOrder(b->lchild);
PostOrder(b->rchild); printf(“%c “,b->data); // 访问根节点
}
}
层次遍历算法

对于一颗二叉树,从根节点开始,按照从上到下,从左到右的顺序访问每一个节点。每一个节点只访问一次。

解决思路:

1. 使用一个队列, 先将根节点进队;

2. 队不空时循环 : 从队列中出列一个节点*p ,访问它 ;

若有左孩子节点,将左孩子节点进队 ;

若有右孩子节点,将右孩子节点进队 。

8fc0fb239f5cd7f7f2000dc927e8712a.png

对应的代码如下:

void LevelOrder(BTNode *b)
{ BTNode *p;
BTNode *qu[MaxSize]; // 定义环形队列, 存放节点指针
int front, rear; // 定义队头和队尾指针
front=rear=0; // 置队列为空队列
rear++;
qu[rear]=b; // 根节点指针进入队列
while (front!=rear) // 队列不 为 空循环
{ front=(front+1)%MaxSize;
p=qu[front]; // 队头出队列
printf("%c ",p->data); // 访问节点
if (p->lchild!=NULL) // 有左孩子时将其进队
{ rear=(rear+1)%MaxSize;
qu[rear]=p->lchild;
} if (p->rchild!=NULL) // 有右孩子时将其进队
{ rear=(rear+1)%MaxSize;
qu[rear]=p->rchild;
}
}
}//算法的时间复杂度为O(n)。

下面我们通过一个例子对三种遍历方式进行验证。给定一个二叉树如图所示:

ac292b5a67daea2141120ba973062274.png

先序遍历序列:ABDGCEF .

先序序列的第一个节点是根节点.

中序遍历序列:DGBAECF

中序序列的根节点左边是左子树的节点,右边是右子树的节点。

后序遍历序列:GDBEFCA

后序序列的最后一个节点是根节点。

层次遍历序列:ABCDEFG

625fe406a3318fd505ae81e8166df03c.png

介绍完四种遍历方法,现在让我们回到文章最开始的问题,如下图所示,

先序序列:N R L 后序序列:L R N 后序序列的反序:N L R

113b5efec03a103f8580b463e1d6e138.png

可以推断出,只有 当L 为空或者R为空时才成立 。以此类推,当我们的二叉树节点数很多的时候,要使得这颗二叉树的先序序列和后序序列正好相反,这样的二叉树每层只有一个节点,即 二叉树的形态是其高度等于节点个数 。例如:

b50ccd6743a13045dcdb1ce616315e55.png

a096f46aae98ac83c7b594dbde3e5213.gif fd8a94e7be3e88495877eb0dcb93b3ad.gif cf1cb9249d19075132cd53479401d837.gif

- End -

52fff0961ee573c9ad240216c8dd7f37.png

点击“在看”,让更多朋友们看到吧~

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP