蓝桥杯训练:简单树——先序和中序遍历转出后序遍历

问题描述:给出二叉树的先序,中序遍历序列,求出其后序遍历序列
作者:何知令
完成时间:2017年8月1日
输入:首行输入该二叉树节点数量,随后一行输入该二叉树前序序列,后一行输入中序序列
输出:该二叉树后序序列
算法思想:找根节点,在左子树中递归,在右子树中递归

代码:

/*
问题描述:给出二叉树的先序,中序遍历序列,求出其后序遍历序列
作者:何知令
完成时间:2017年8月1日
输入:首行输入该二叉树节点数量,随后一行输入该二叉树前序序列,后一行输入中序序列
输出:该二叉树后序序列
算法思想:找根节点,在左子树中递归,在右子树中递归
*/
#include <iostream>
#include <malloc.h>
using namespace std;
char pre[100],in[100];
typedef struct TreeNode
{
    struct TreeNode *lchild;
    struct TreeNode *rchild;
    char data;
} BTNode;
BTNode * CreateBT(char *pre,char *in,int n)
{
    BTNode *b;
    char r,*p;
    int k;
    if(n<=0)return NULL;
    r=*(pre);//根节点值
    b=(BTNode *)malloc(sizeof(BTNode));//申请一个BTNode类型的存储空间
    b->data=r;
    for(p=in; p<in+n; p++)
        if(*p==r)
            break;
    k=p-in;//该根节点的左子树节点数量
    b->lchild=CreateBT(pre+1,in,k);//对其左子树进行建树
    b->rchild=CreateBT(pre+k+1,p+1,n-k-1);//对其右子树进行建树
    return b;
}
void postVistBT(BTNode *b)
{
    if(b!=NULL)
    {
        preVistBT(b->lchild);
        preVistBT(b->rchild);
        cout<<b->data<<' ';
    }
}
int main()
{
    int n,i;
    BTNode *bt;
    cin>>n;
    for(i=0; i<n; i++)
        cin>>pre[i];
    for(i=0; i<n; i++)
        cin>>in[i];
    bt=CreateBT(pre,in,n);
    postVistBT(bt);
    return 0;
}

知识点总结:二叉树的遍历方式及二叉树的建立

学习心得:还是看了书上的代码才弄出来的

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 先序遍历、中序遍历后序遍历都是二叉遍历的方法,它们的区别在于访问根节点的顺序和访问左右子的顺序不同。 1. 先序遍历 先序遍历的访问顺序是:根节点 -> 左子 -> 右子。 例如,对于下面这棵二叉: ``` 1 / \ 2 3 / \ / \ 4 5 6 7 ``` 其先序遍历序列为:1 2 4 5 3 6 7。 2. 中序遍历 中序遍历的访问顺序是:左子 -> 根节点 -> 右子。 例如,对于下面这棵二叉: ``` 1 / \ 2 3 / \ / \ 4 5 6 7 ``` 其中序遍历序列为:4 2 5 1 6 3 7。 3. 后序遍历 后序遍历的访问顺序是:左子 -> 右子 -> 根节点。 例如,对于下面这棵二叉: ``` 1 / \ 2 3 / \ / \ 4 5 6 7 ``` 其后序遍历序列为:4 5 2 6 7 3 1。 希望这个回答能够解决您的疑惑。 ### 回答2: 先序遍历、中序遍历后序遍历是二叉的三种常见遍历方式。 先序遍历:先访问根节点,然后遍历左子,最后遍历右子。在遍历的过程中,根节点总是在左子和右子之前被访问到。 中序遍历:先遍历左子,然后访问根节点,最后遍历右子。在遍历的过程中,根节点总是在左子和右子之间被访问到。 后序遍历:先遍历左子,然后遍历右子,最后访问根节点。在遍历的过程中,根节点总是在左子和右子之后被访问到。 以一个简单的二叉为例,如下所示: A / \ B C / \ \ D E F 先序遍历:A -> B -> D -> E -> C -> F 中序遍历:D -> B -> E -> A -> C -> F 后序遍历:D -> E -> B -> F -> C -> A 其中,先序遍历的访问顺序是根节点->左子->右子中序遍历的访问顺序是左子->根节点->右子后序遍历的访问顺序是左子->右子->根节点。 这三种遍历方式都有自己的应用场景。先序遍历常用于打印表达式,中序遍历常用于二叉搜索中序输出,后序遍历常用于计算二叉的表达式。 总之,先序遍历、中序遍历后序遍历是对二叉的不同遍历顺序,每种遍历方式都有自己的特点和应用场景。 ### 回答3: 先序遍历、中序遍历后序遍历都是二叉遍历的方法。下面分别对这三种遍历进行简单的说明。 先序遍历是指从根节点开始,先遍历根节点,然后按照先序遍历的顺序,递归遍历左子和右子。具体步骤如下:先输出根节点,然后递归遍历左子,最后递归遍历右子中序遍历是指从根节点开始,先递归遍历左子,然后输出根节点,最后再递归遍历右子。具体步骤如下:先递归遍历左子,然后输出根节点,最后递归遍历右子后序遍历是指从根节点开始,先递归遍历左子,然后递归遍历右子,最后输出根节点。具体步骤如下:先递归遍历左子,然后递归遍历右子,最后输出根节点。 这三种遍历方法都是通过递归的方式实现的,其中先序遍历和中序遍历的次序不同,而后序遍历的次序更为靠后。不同的遍历方式可以帮助我们了解二叉结构的不同特点,如先序遍历可以轻松找到二叉的根节点,中序遍历可以输出二叉的有序节点序列,后序遍历可以方便地进行二叉的删除操作。 总结起来,先序遍历中序遍历后序遍历都是二叉遍历的方法,只不过它们的递归次序不同。熟练掌握这三种遍历方式可以帮助我们更好地理解二叉的结构和特点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值