A30888.【算法】Gold King的二叉树遍历3

入门

官方

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

Gold King已经掌握了二叉树的先中后序递归形式遍历,由于是两个递归调用,让程序执行的效率低下,于是Gold King想着有没有优化的方式。
在对Gold King的二叉树遍历1中的二叉搜索树观察研究中,Gold King发现一种先序的非递归实现方式:
1、将二叉树的根节点当作当前正在遍历的结点
2、若当前结点非空,则先访问该结点,并将该结点压进栈,再将其左孩子结点作为当前遍历节点,重复步骤2,直到遍历到的结点为空为止
3、之后若栈非空,则栈顶结点出栈,并将当前结点的右孩子结点作为当前遍历结点
重复

输入格式

第一行输入一个整数n,表示有n个数。
第二行输入n个整数ai,表示对应n个数据(题目保证ai各不相同)。

输出格式

第一行输出对应二叉搜索树的先序遍历结果,
第二行输出每次当前遍历输出时,栈中元素个数。
每个数据占5个域宽。

输入输出样例

  • 输入#1

    7
    23 13 10 30 54 46 77
    

    输出#1

       23   13   10   30   54   46   77
        1    2    3    1    1    2    1
    

说明/提示

3 <=n <=100
1 <= ai <=1000

  样例1数据构建的二叉树如下图:


  



    对应先序遍历输出23时,栈中压入23,栈中个数为1;输出13时,栈中压入13,栈中个数为2;输出10时,栈中压入10,栈中个数为3;输出30时,栈中已经弹出10、13、23,再压入30,栈中个数为1;输出54时,栈中已经弹出30,再压入54,栈中个数为1;输出46时,栈中压入46,栈中个数为2;输出77时,栈中已经弹出46、54,再压入23,栈中个数为1。
首页