首页 > 其他 > 详细

二叉树遍历 ——已知后序,中序求层序 A1020.(25)

时间:2020-01-21 22:41:20      阅读:80      评论:0      收藏:0      [点我收藏+]

技术分享图片

 

 若直接DFS递归求解,会栈溢出

#include <cstdio>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std;
const int maxn=50;
struct node{
    int data;
    node* lchild;
    node* rchild;
};
int pre[maxn],in[maxn],post[maxn];//先序,中序,后序
int n; //结点个数
//当前二叉树的后续序列区间为[postL,postR],中序序列区间为[inL,inR]
//create函数返回构建出的二叉树的根节点地址
node* create(int postL,int postR,int inL,int inR){
    if(postL>postR){
        return NULL;//后序序列长度小于等于0时,直接返回 
    }
    node* root=new node;//新建一个新的结点,用来存放当前二叉树的根节点
    root->data=post[postR];
    int k;
    for(k=inL;k<=inR;k++){
        if(in[k]==post[postR]){//在中序遍历中找到等于根节点指向的data 
            break;
        }
    }
    int numLeft=k-inL;//左子树的节点个数
    //返回左子树的根节点地址,赋值给root的左指针
    root->lchild=create(postL,postL+numLeft-1,inL,k-1);
    //返回右子树的根节点地址,赋值给root的右指针
    root->rchild=create(postL+numLeft,postR-1,k+1,inR);
    return root;//返回根节点地址      
} 
int num=0; //已输出的结点个数
void BFS(node* root){
    queue<node*> q; //注意队列里是存地址
    q.push(root);//将根节点地址入队
    while(!q.empty()){
        node* now=q.front();//取出队首元素
        q.pop();
        printf("%d",now->data);//访问队首元素的data
        num++;
        if(num<n) printf(" ");
        if(now->lchild!=NULL) q.push(now->lchild);//左子树非空
        if(now->rchild!=NULL) q.push(now->rchild);//右子树非空 
    } 
}
int main(){
    scanf("%d",&n);
    for(int i=0;i<n;i++){
        scanf("%d",&post[i]);
    }
    for(int i=0;i<n;i++){
        scanf("%d",&in[i]);
    }
    node* root=create(0,n-1,0,n-1);//建树
    BFS(root);//层序遍历 
    return 0; 
} 

二叉树遍历 ——已知后序,中序求层序 A1020.(25)

原文:https://www.cnblogs.com/JasonPeng1/p/12227156.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!