题目:
例:输入一棵二叉树,你的任务是按从上到下,从左到右的顺序输出每一个节点的值。每个节点都按照从根节点到它的移动序列给出(L表示左,R表示右)。在输入中,每个节点的左括号和右括号之间没有空格,相邻节点之间用一个空格隔开。每课树的输入用一对空括号“()”结束(这对括号本身不代表任何节点)。注意,如果从根到某个节点的路径上有的节点没有在输入的中给出,或者给出超过一次,输出not complete。节点个数不超过256个。
样例输入:
(11,LL) (7,LLL) (8,R) (5,) (4,L) (13,RL) (2,LLR) (1,RRR) (4,RR) ()
(3,L) (4,R) ()
样例输出:
5 4 8 11 13 4 7 2 1
-1
分析与解答
1.整体来说需要:输入,建立结点,将其组织成一棵树,利用bfs,队列进行层次遍历,输出
2.二叉树结点定义,一个结点:树根的值,左子树(还是结点类型),右子树。(递归定义),每次需要新node,调用newnode
3.数据填到树上,从根开始,按照输入,往左往右走,如果目标不存在,调用newnode
4.按层次顺序遍历,每次取出一个结点,把他左右子节点放进队列,取出q.front放到输出序列vector里
5.遍历vector,输出即可
6.为了防止内存被浪费,需要