zoukankan      html  css  js  c++  java
  • 玩转二叉树(二叉树的遍历)

    玩转二叉树

    时间限制
    400 ms
    内存限制
    65536 kB
    代码长度限制
    8000 B
    判题程序
    Standard
    作者
    陈越

    给定一棵二叉树的中序遍历和前序遍历,请你先将树做个镜面反转,再输出反转后的层序遍历的序列。所谓镜面反转,是指将所有非叶结点的左右孩子对换。这里假设键值都是互不相等的正整数。

    输入格式:

    输入第一行给出一个正整数N(<=30),是二叉树中结点的个数。第二行给出其中序遍历序列。第三行给出其前序遍历序列。数字间以空格分隔。

    输出格式:

    在一行中输出该树反转后的层序遍历的序列。数字间以1个空格分隔,行首尾不得有多余空格。

    输入样例:
    7
    1 2 3 4 5 6 7
    4 1 3 2 6 5 7
    
    输出样例:
    4 6 1 7 5 3 2
    #include <cstdio>  
    #include <algorithm>  
    #include <iostream>  
    #include <set> 
    #include<queue>
    #include<cstring>
    #include<string>
    #include<cstdio>
    using namespace std;  
    int md[55];
    int sd[55];
    queue<int>q;
    struct node
    {
        int l,r;
    }tree[355];
    
    int build(int la,int ra,int lb,int rb)  
    {  
        if(lb>rb)return 0;  
        int rt=sd[la],p1=lb,p2;  
        while(md[p1]!=rt)p1++;  
        p2=p1-lb;  
        tree[rt].l=build(la+1,la+p2,lb,p1-1);  
        tree[rt].r=build(la+p2+1,ra,p1+1,rb);  
        return rt;  
    }  
    
    int a[355];
    int ans=1;
    
    void bfs(int root)
    {
        q.push(root);
        while(!q.empty())
        {
            int v=q.front();q.pop();
            a[ans++]=v;
            if(tree[v].r) q.push(tree[v].r);
            if(tree[v].l) q.push (tree[v].l);
            
        }
    }
    
    
    int main()
    {
        int n;
        cin>>n;
        for(int i=1;i<=n;i++) cin>>md[i];
        for(int i=1;i<=n;i++) cin>>sd[i];
        build(1,n,1,n);
        bfs(sd[1]);
        for(int i=1;i<=ans-1;i++)
        {
            cout<<a[i];
            if(i!=ans-1) cout<<" ";
        }
        return 0;
    }



  • 相关阅读:
    Java基础知识(一)环境变量的设置、变量与常量、自动类型转换、自增长、赋值运算符
    ModelState
    DOM
    正则表达式常见形式
    通过JS设置一个元素的文本
    JS(三) 原型对象与原型链
    JS(二)call方法和apply方法
    第四周学习进度表
    敏捷开发方法综述
    数组02
  • 原文地址:https://www.cnblogs.com/caiyishuai/p/8646943.html
Copyright © 2011-2022 走看看