首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
输入一颗二元树,从上往下按层打印树的每个结点,同一层中按照从左往右的顺序打印。 输出8 6 10 5 7 9 11。
输入一颗二元树,从上往下按层打印树的每个结点,同一层中按照从左往右的顺序打印。 输出8 6 10 5 7 9 11。
admin
2019-03-29
112
问题
输入一颗二元树,从上往下按层打印树的每个结点,同一层中按照从左往右的顺序打印。
输出8 6 10 5 7 9 11。
选项
答案
#include
#include
using namespace std; struct BTreeNode // a node in the binary tree { int m_nValue; // value of node BTreeNode *m_pLeft; // left child of node BTreeNode *m_pRight; // right child of node }; /////////////////////////////////////////////////////////////////////// // Print a binary tree from top level to bottom level // Input: pTreeRoot - the root of binary tree /////////////////////////////////////////////////////////////////////// void PrintFromTopToBottom(BTreeNode *pTreeRoot) { if(!pTreeRoot) return; // get a empty queue deque
dequeTreeNode; // insert the root at the tail of queue dequeTreeNode.push_back(pTreeRoot); while(dequeTreeNode.size()) { // get a node from the head of queue BTreeNode *pNode = dequeTreeNode.front(); dequeTreeNode.pop_front(); // print the node cout << pNode->m_nValue << ’ ’; // print its left child sub-tree if it has if(pNode->m_pLeft) dequeTreeNode.push_back(pNode->m_pLeft); // print its right child sub-tree if it has if(pNode->m_pRight) dequeTreeNode.push_back(pNode->m_pRight); } }
解析
这曾是微软的一道面试题。这道题实质上是要求遍历一棵二元树,只不过不是我们熟悉的前序、中序或者后序遍历。
我们从树的根结点开始分析。自然先应该打印根结点8,同时为了下次能够打印8的两个子结点,我们应该在遍历到8时把子结点6和10保存到一个数据容器中。现在数据容器中就有两个元素6 和10了。按照从左往右的要求,我们先取出6访问。打印6的同时要把6的两个子结点5和7放入数据容器中,此时数据容器中有三个元素10、5和7。接下来我们应该从数据容器中取出结点10访问了。注意10比5和7先放入容器,此时又比5和7先取出,就是我们通常说的先入先出。因此不难看出这个数据容器的类型应该是个队列。
既然已经确定数据容器是一个队列,现在的问题变成怎么实现队列了。实际上我们无需自己动手实现一个,因为STL已经为我们实现了一个很好的deque(两端都可以进出的队列),我们只需要拿过来用就可以了。
我们知道树是图的一种特殊退化形式。同时如果对图的深度优先遍历和广度优先遍历有比较深刻的理解,将不难看出这种遍历方式实际上是一种广度优先遍历。因此这道题的本质是在二元树上实现广度优先遍历。
转载请注明原文地址:https://kaotiyun.com/show/YRmZ777K
0
程序员面试
相关试题推荐
Thecommitteehasanticipatedtheproblemsthat______intheroadconstructionproject.
定义栈的数据结构,要求添加一个min函数,能够得到栈的最小元素。要求函数min、push以及pop的时间复杂度都是O(1)。
求1+2+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字以及条件判断语句(A?B:C)。
大概描述一下ASP。NET页面的生命周期
.asp.net如何实现MVC模式,举例说明!
输入一个整数数组,调整数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。要求时间复杂度为O(n)。
如果要将页面上的某个图形设计成页面下载后显示在页面上,当鼠标放在它的上面时,该图形变为另一图形,那么可以通过______方法来设置。A.使用时间线B.“RolloverImage”命令C.将图形插入到表格中D.使用层与行为
软盘写保护的作用是()。A.防止持签B.防止读盘C.防止显示D.防止写盘
类型声明语句为:INTEGER(2)::I数据输出语句为:PRINT,I变量I中数据输出域宽是____________字符。
随机试题
核心能力目标是大企业发展能力目标之一,大型企业的核心能力目标主要是企业创新能力目标,包括()
具有结肠带、结肠袋和肠脂垂的肠管是()
A.蛋白质CB.蛋白质SC.凝血酶调制素D.TFPIE.抗凝血酶Ⅲ能灭活FⅤa、FⅧ的物质是
酸中毒时,肾小管重吸收和分泌功能的改变是
呕吐物多且有粪臭者见于
假定剪扭构件混凝土受扭承载力降低系数的计算值为βt=1.26,试问该构件在剪扭力的作用下,其受扭纵筋的最小配筋率与下列( )项数值相近。假定该构件承受的弯矩设计值M=100kN·m,扭矩设计值T=20kN·m,剪力设计值为V=85kN,箍筋间距为10
根据铝的工艺特点,铝合金可分为( )。
M公司发生部分经济业务如下:(1)6月1日,“应收账款”账户借方余额为600000元,两个所属明细账户的余额分别为:“X企业”借方余额400000元,“Y企业”借方余额200000元。(2)6月10日,向甲公甸采购材料,按合同规定向甲公司预付货款400
随着家庭成员年年龄的增大,叶先生急需为自己的家庭作一个理财计划,假如你接到了这个客户的要求,经过初步沟通面谈后,获得了以下家庭、职业与财务信息:一、家庭成员状况四、保险情况叶先生和叶太太拥有社保,儿子叶明保额为2万元的寿险。五、理财目标1.为儿
下列选项中,不属于商业银行在贷款审批要素管理中存在的问题的是()。
最新回复
(
0
)