二叉树的遍历(后序+中序)

已知二叉树的后序遍历和中序遍历,求出它的前序遍历

与前一个不同的,二叉树的后序遍历的最后一个节点才是根节点,所以此时只需要用后序遍历的最后一个元素为标记,其他与前一篇文章一样,下面是代码。

/* 8 GDAFEMHZ ADEFGHMZ * AEFDHZMG */
#include<iostream>
#include<cstring>
using namespace std;
void binarytree(char a[],char b[],int len)
{
    int i;
    if (len==0)
    return ;
    for (i=0;i<len;i++)
    {
        if (b[i]==*a)
        break;
    }
    binarytree(a+1,b,i);
    binarytree(a+i+1,b+i+1,len-i-1);
    cout<<a[0];
}
int main()
{
    int n;
    cin>>n;
    char pre[n],mid[n];
    scanf("%s %s",pre,mid);
    binarytree(pre,mid,n);
}
全部评论

相关推荐

07-28 16:37
门头沟学院 Java
哎,继续加油吧
ResourceUt...:能接到面试就已经是✌🏻了
腾讯一面2191人在聊
点赞 评论 收藏
分享
07-20 21:57
已编辑
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务