【2024华为OD机试真题-C卷D卷-200分】二叉树的广度优先遍历(C++/Java/Python)

该博客介绍了如何解决华为在线评估(OD)机试中关于二叉树层序遍历的问题。通过分析后序遍历和中序遍历的结果,利用广度优先搜索(BFS)重建二叉树并输出层序遍历顺序。文章提供了C++、Java和Python的代码实现。
摘要由CSDN通过智能技术生成

【华为OD机试】-(A卷+B卷+C卷+D卷)-2024真题合集目录

【华为OD机试】-(C卷+D卷)-2024最新真题目录

题目描述

有一棵二叉树,每个节点由一个大写字母标识(最多26个节点)。

现有两组字母,分别表示后序遍历(左孩子->右孩子->父节点)和中序遍历(左孩子->父节点->右孩子)的结果,请你输出层序遍历的结果。

输入描述

每个输入文件一行,第一个字符串表示后序遍历结果,第二个字符串表示中序遍历结果。(每串只包含大写字母)

中间用单空格分隔。

输出描述

输出仅一行,表示层序遍历的结果,结尾换行。

用例1
输入 CBEFDA CBAEDF
输出 ABDCEF
说明

二叉树为:

     A
    /   \
  B    D
 /      /  \
C    E   F

题目解析

二叉树的三种遍历方式:

  • 前(根)序遍历:根左右
  • 中(根)序遍历:左根右
  • 后(根)序遍历:左右根

前中后是指根节点出现的位置,三种遍历方式只有根节点的顺序不一样,左右节点的顺序不变。

后序遍历的最后一个节点肯定是根节点,由例子中后序遍历的结果CBEFDA可以知道根节点为A。在中序遍历中,根节点在中间位置出现,根节点的坐边就是左子树,右边是右子树。由中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2024剑指offer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值