题目

给定一个二叉树,返回其按层次遍历的节点值。 (即逐层地,从左到右访问所有节点)。

例如:

给定二叉树: [3,9,20,null,null,15,7],

    3
/ \
9 20
/ \
15 7

返回其层次遍历结果:

[
[3],
[9,20],
[15,7]
]

考点


思路


代码

newcoder

/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};
*/
class Solution {
public:
vector<vector<int> > Print(TreeNode* pRoot) {
//1.定义返回结果
vector<vector<int>> ret;
vector<int> subret;
//2.入口检查
if(!pRoot)
return ret; //3.定义变量和队列
int toBePrinted=1;//这一级还剩的节点数
int NextLevel=0;//下一级的节点数
queue<TreeNode*> queueTree;
int level=0;//当前的级数
//4.放入根节点
queueTree.push(pRoot); //5.循环
while(!queueTree.empty())
{
TreeNode* cur=queueTree.front();
subret.push_back(cur->val);
queueTree.pop(); //如果有左子节点
if(cur->left)
{
queueTree.push(cur->left);
NextLevel++;
} //如果有右子节点
if(cur->right)
{
queueTree.push(cur->right);
NextLevel++;
} toBePrinted--;
if(!toBePrinted)
{
level++;
toBePrinted=NextLevel;
NextLevel=0;
ret.push_back(subret);
subret.clear();
}
} return ret;
} };

leetcode

/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
vector<vector<int>> levelOrder(TreeNode* root) { //1.返回容器
vector<int> subret;
vector<vector<int>> ret; //2.入口检查
if(!root)
return ret; //3.定义变量和队列
//该层还剩打印的节点
int remain=1;
//下层的节点数
int nextLevel=0; //树节点队列
queue<TreeNode*> nodes; //将根节点入队列
nodes.push(root); //4.将队列元素放入容器
while(!nodes.empty())
{
//存储当前节点为队列的头部
TreeNode* cur = nodes.front();
//将当前节点塞入subret
subret.push_back(cur->val);
nodes.pop();
remain--; if(cur->left)
{
nextLevel++;
nodes.push(cur->left);
} if(cur->right)
{
nextLevel++;
nodes.push(cur->right);
} //当前级元素全部读完
if(!remain)
{
//将subret pushback进ret
ret.push_back(subret);
//将下一层的剩余元素个数更新
remain=nextLevel;
//下一层的下一层初始化为0
nextLevel=0;
//清空subret
subret.clear();
} } //5.返回ret
return ret; }
};

问题

1.queue

Member functions

(constructor)

empty

size

front

back

push

emplace 

Construct and insert element (public member function )

pop

swap 

Swap contents (public member function )

Non-member function overloads

relational operators

Relational operators for queue (function )

swap (queue) 

Exchange contents of queues (public member function )

queue只有push()。。。vector deque才用push_back()


2.二维vector遍历

#include<iostream>
#include<vector> using namespace std; int main()
{
vector<vector<int>> ves;
vector<int> a{ 1, 2, 3 };
vector<int> b{ 2, 4, 5, 6 }; ves.push_back(a);
ves.push_back(b);
for (auto it = ves.begin(); it != ves.end(); ++it){
for (int i = 0; i < (*it).size(); ++i)
cout << (*it)[i] << " " ;
}
}

这题就用subret和ret来定义返回值,注意每层subret要清空。 

32-2题:LeetCode102. Binary Tree Level Order Traversal二叉树层次遍历/分行从上到下打印二叉树的更多相关文章

  1. [刷题] 102 Binary Tree Level Order Traversal

    要求 对二叉树进行层序遍历 实现 返回结果为双重向量,对应树的每层元素 队列的每个元素是一个pair对,存树节点和其所在的层信息 1 Definition for a binary tree node ...

  2. 剑指offer从上往下打印二叉树 、leetcode102. Binary Tree Level Order Traversal(即剑指把二叉树打印成多行、层序打印)、107. Binary Tree Level Order Traversal II 、103. Binary Tree Zigzag Level Order Traversal(剑指之字型打印)

    从上往下打印二叉树这个是不分行的,用一个队列就可以实现 class Solution { public: vector<int> PrintFromTopToBottom(TreeNode ...

  3. LeetCode102 Binary Tree Level Order Traversal Java

    题目: Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to ri ...

  4. (二叉树 BFS) leetcode102. Binary Tree Level Order Traversal

    Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...

  5. leetcode102 Binary Tree Level Order Traversal

    """ Given a binary tree, return the level order traversal of its nodes' values. (ie, ...

  6. Binary Tree Level Order Traversal,层序遍历二叉树,每层作为list,最后返回List<list>

    问题描述: Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to ...

  7. Leetcode102. Binary Tree Level Order Traversal二叉树的层次遍历

    给定一个二叉树,返回其按层次遍历的节点值. (即逐层地,从左到右访问所有节点). 例如: 给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7 返回其 ...

  8. (二叉树 BFS) leetcode 107. Binary Tree Level Order Traversal II

    Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left ...

  9. [Leetcode] Binary tree level order traversal ii二叉树层次遍历

    Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left ...

随机推荐

  1. Java中keytool管理证书

    1.创建证书库以及第一个证书 keytool -genkeypair -alias "wangpass" -keyalg "RSA" -keystore &qu ...

  2. python学习笔记(一)——关于正则表达式的学习小结

    python中提供了re这个模块提供对正则表达式的支持. 一.正则表达式常用到的一些语法(并非全部): . 匹配任意单个字符 [...] 匹配单个字符集 \w 匹配单词字符,即[a-zA-Z0-9] ...

  3. 深刻理解Linux进程间通信(IPC)

    https://www.ibm.com/developerworks/cn/linux/l-ipc/ linux下进程间通信的几种主要手段简介: 管道(Pipe)及有名管道(named pipe):管 ...

  4. Hive 基本语法操练(五):Hive 的 JOIN 用法

    Hive 的 JOIN 用法 hive只支持等连接,外连接,左半连接.hive不支持非相等的join条件(通过其他方式实现,如left outer join),因为它很难在map/reduce中实现这 ...

  5. Angular 8 发布

    原文地址:https://blog.angular.io/version-8-of-angular-smaller-bundles-cli-apis-and-alignment-with-the-ec ...

  6. Maven的安装以及介绍

    附录:带阿里源的maven用户设置文件-settings.xml <?xml version="1.0" encoding="UTF-8"?> &l ...

  7. Aura Component Skills & Tools

    本篇参考: https://trailhead.salesforce.com/content/learn/modules/lex_dev_lc_vf_fundamentals 不知不觉已经做了三年多的 ...

  8. Reactor Pattern and Non-blocking IO--reference

    reference from:http://www.cs.bgu.ac.il/~spl051/Personal_material/Practical_sessions/Ps_12/ps12.html ...

  9. Docker | 第四章:Dockerfile简单介绍及使用

    前言 前一章节,介绍了Docker常用的命令.在基本使用上,熟悉这些常用的命令基本上就够了.但在一些场景下,比如在部署SpringBoot应用时,通常我们都是打成Jar包,然后利用java命令进行运行 ...

  10. SpringMVC04 很杂很重要(注解,乱码处理,通配符,域属性调用,校正参数名称,访问路径,请求、响应携带参数,请求方法)

    1.导入架包 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3 ...