题目:输入一颗二元树,从上往下按层打印树的每个结点,同一层中按照从左往右的顺序打印。例如输入
8
/ \
6 10
/\ /\
5 7 9 11
输出8 6 10 5 7 9 11。
分析:这曾是微软的一道面试题。这道题实质上是要求遍历一棵二元树,只不过不是我们熟悉的前序、中序或者后序遍历。
我们从树的根结点开始分析。自然先应该打印根结点8,同时为了下次能够打印8的两个子结点,我们应该在遍历到8时把子结点6和10保存到一个数据容器中。现在数据容器中就有两个元素6 和10了。按照从左往右的要求,我们先取出6访问。打印6的同时要把6的两个子结点5和7放入数据容器中,此时数据容器中有三个元素10、5和7。接下来我们应该从数据容器中取出结点10访问了。注意10比5和7先放入容器,此时又比5和7先取出,就是我们通常说的先入先出。因此不难看出这个数据容器的类型应该是个队列。
既然已经确定数据容器是一个队列,现在的问题变成怎么实现队列了。实际上我们无需自己动手实现一个,因为STL已经为我们实现了一个很好的deque(两端都可以进出的队列),我们只需要拿过来用就可以了。
我们知道树是图的一种特殊退化形式。同时如果对图的深度优先遍历和广度优先遍历有比较深刻的理解,将不难看出这种遍历方式实际上是一种广度优先遍历。因此这道题的本质是在二元树上实现广度优先遍历。
参考代码:
#include <deque>
#include <iostream>
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<BTreeNode *> 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);
}
}
程序员面试题精选100题(12)-从上往下遍历二元树[数据结构]
时间:2019-09-22
- 私立学校怎样面试?参考这些真题做好准备(天府第七中学面试题)
- 成都市2017小升初私立学校面试攻略和去年真题汇总
- 广州2017年公办小学面试
- 程序员面试题精选100题(63)-数组中三个只出现一次的数字
- 程序员面试题精选100题(62)-C/C++/C#面试题(5)
- 程序员面试题精选100题(61)-数对之差的最大值[算法]
- 程序员面试题精选100题(60)-判断二叉树是不是平衡[数据结构]
- 程序员面试题精选100题(59)-字符串的组合[算法]
本文已影响
人好书推荐
最新文章
推荐文章
推荐栏目
- 剧情介绍
- 早晚安心语
- 初中学习方法
- 教育资讯
- 办公表格
- 论文大全
- 理财知识
- 高中学习方法
- 简历下载
- 路由器
- 脑力开发
- 放假安排
- 作文大全
- 读后感
- 介绍信
- 感谢信
- 承诺书
- 节日大全
- Office教程
- 述职报告
- 标语
- 评语
- 合同范本
- 情书
- 请假条
- 责任书
- 请示
- 感言
- 方案大全
- 常用证明
- 口号
- 观后感
- 自我介绍
- 常识
- 弟子规
- 倡议书
- 日记
- 句子大全
- 大学
- 美文
- 职场顾问
- 唐诗
- 党团范文
- 语文
- 申请书
- 课件
- 历史故事
- 主题班会
- 调研报告
- 经典台词
- 说说大全
- 编程笔记
- 歇后语
- 自我评价
- 通知
- 应急预案
- 广告语
- 三字经
- 规章制度
- 邀请函
- 检讨书
- 委托书
- 加油稿
- 工作计划
- 实习范文
- 教案
- 工作总结
- 社保
- 政策法规
- 员工手册
- 讲话致辞
- 求职面试
- 辞职报告
- 自我鉴定
- 心得体会
- 社会实践报告
- 岗位职责
- 周公解梦
- 事迹材料