zoukankan      html  css  js  c++  java
  • 复习题之二叉树的遍历

    3143 二叉树的序遍历

     

     时间限制: 1 s
     空间限制: 32000 KB
     题目等级: 白银 Silver
     
     
    题目描述 Description

    求一棵二叉树的前序遍历,中序遍历和后序遍历

    输入描述 Input Description

    第一行一个整数n,表示这棵树的节点个数。

    接下来n行每行2个整数L和R。第i行的两个整数Li和Ri代表编号为i的节点的左儿子编号和右儿子编号。

    输出描述 Output Description

    输出一共三行,分别为前序遍历,中序遍历和后序遍历。编号之间用空格隔开。

    样例输入 Sample Input

    5

    2 3

    4 5

    0 0

    0 0

    0 0

    样例输出 Sample Output

    1 2 4 5 3

    4 2 5 1 3

    4 5 2 3 1

    数据范围及提示 Data Size & Hint

    n <= 16

    分类标签 Tags 

    递归 搜索
     
     
    #include<cstdio>
    using namespace std;
    void front(int a[110][3],int n)
    {
        if(n==0)return ;
        printf("%d ",n);
        front(a,a[n][1]);
        front(a,a[n][2]);
    }
    void middle(int a[110][3],int n)
    {
        if(n==0)return ;
        middle(a,a[n][1]);
        printf("%d ",n);
        middle(a,a[n][2]);
    }
    void behind(int a[110][3],int n)
    {
        if(n==0)return ;
        behind(a,a[n][1]);
        behind(a,a[n][2]);
        printf("%d ",n);
    }
    int a[110][3],n;
    int main()
    {
        scanf("%d",&n);
        for(int i=1;i<=n;i++)
        {
            a[i][0]=i;
            scanf("%d%d",&a[i][1],&a[i][2]);
        }
        front(a,a[1][0]);
        printf("
    ");
        middle(a,a[1][0]);
        printf("
    ");
        behind(a,a[1][0]);
        return 0;
    }
  • 相关阅读:
    2020.10.31
    2020.10.26
    2020.10.29
    2020.10.28动手动脑+验证
    2020.11.1(每周学习总结)
    2020.10.30
    2020.11.2动手动脑➕课后试验性问题
    Javascript权威指南阅读笔记第3章类型、值和变量(1)
    【一个小功能】从js判断ie版本,浅谈navigator对象的appName属性
    【Vue】vif与vshow的区别
  • 原文地址:https://www.cnblogs.com/EvilEC/p/6855556.html
Copyright © 2011-2022 走看看