问题描述:

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

For example:
Given binary tree [3,9,20,null,null,15,7],

    3
/ \
9 20
/ \
15 7

return its level order traversal as:

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

算法分析:三种方法。这道题和普通的层序遍历不一样的地方就是,需要每层单独输出。因此可以考虑用来两个队列,每个队列存放不同层的节点。我自己写的代码有重复的结构,并不友好。参考网上,其实将第二个队列赋值给第一个队列就行,就不会有重复代码了。也无需考虑队列空的情况了。第三种方法其实就是按层遍历的一种思想,是第二种方法的优化。

public class BinaryTreeLevelOrderTraversal
{
public List<List<Integer>> levelOrder(TreeNode root)
{
List<List<Integer>> res = new ArrayList<>();
if(root == null)
{
return res;
}
Deque<TreeNode> queue1 = new ArrayDeque<>();
Deque<TreeNode> queue2 = new ArrayDeque<>();
queue1.offer(root);
while(!queue1.isEmpty() || !queue2.isEmpty())
{
List<Integer> list1 = new ArrayList<>();
while(!queue1.isEmpty())
{
TreeNode temp = queue1.poll();
if(temp.left != null)
{
queue2.offer(temp.left);
}
if(temp.right != null)
{
queue2.offer(temp.right);
}
list1.add(temp.val);
}
if(list1.size() != 0)//队列空的时候,list1的大小为0
res.add(list1);
List<Integer> list2 = new ArrayList<>();
while(!queue2.isEmpty())
{
TreeNode temp = queue2.poll();
if(temp.left != null)
{
queue1.offer(temp.left);
}
if(temp.right != null)
{
queue1.offer(temp.right);
}
list2.add(temp.val);
}
if(list2.size() != 0)
res.add(list2);
} return res;
} public List<List<Integer>> levelOrder2(TreeNode root)
{
List<List<Integer>> res = new ArrayList<>();
List<Integer> list = new ArrayList<>();
if(root == null)
{
return res;
} ArrayDeque<TreeNode> curr = new ArrayDeque<>();
ArrayDeque<TreeNode> next = new ArrayDeque<>(); curr.offer(root); while(!curr.isEmpty())
{
TreeNode temp = curr.poll();
if(temp.left != null)
{
next.offer(temp.left);
}
if(temp.right != null)
{
next.offer(temp.right);
} list.add(temp.val); if(curr.isEmpty())
{
res.add(list);
list = new ArrayList<Integer>();
curr = next;
next = new ArrayDeque<>();
}
} return res;
} public List<List<Integer>> levelOrder3(TreeNode root)
{
List<List<Integer>> res = new ArrayList<>(); if(root == null)
{
return res;
}
ArrayList<TreeNode> arr = new ArrayList<>();
arr.add(root);
while(!arr.isEmpty())
{
List<Integer> list = new ArrayList<>();
ArrayList<TreeNode> temp = new ArrayList<>();
for (TreeNode node : arr)
{
list.add(node.val);
if(node.left != null)
{
temp.add(node.left);
}
if(node.right != null)
{
temp.add(node.right);
}
}
res.add(list);
arr = temp;
} return res;
} public List<List<Integer>> levelOrderBottom(TreeNode root) {
List<List<Integer>> res = new ArrayList<>();
List<Integer> list = new ArrayList<>(); Deque<TreeNode> curr = new ArrayDeque<>();
Deque<TreeNode> next = new ArrayDeque<>(); if(root == null)
{
return res;
} curr.offer(root);
while(! curr.isEmpty())
{
TreeNode temp = curr.poll(); if(temp.left != null)
{
next.offer(temp.left);
}
if(temp.right != null)
{
next.offer(temp.right);
} list.add(temp.val); if(curr.isEmpty())
{
res.add(list);
list = new ArrayList<>();
curr = next;
next = new ArrayDeque<>();
}
} List<List<Integer>> reverseRes = new ArrayList<>();
for(int i = res.size()-1; i >= 0; i --)
{
reverseRes.add(res.get(i));
}
return reverseRes;
}
}

  

Binary Tree Level Order Traversal,层序遍历二叉树,每层作为list,最后返回List<list>的更多相关文章

  1. LeetCode之Binary Tree Level Order Traversal 层序遍历二叉树

    Binary Tree Level Order Traversal 题目描述: Given a binary tree, return the level order traversal of its ...

  2. 102. Binary Tree Level Order Traversal ------层序遍历

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

  3. LeetCode 107 Binary Tree Level Order Traversal II(二叉树的层级顺序遍历2)(*)

    翻译 给定一个二叉树,返回从下往上遍历经过的每一个节点的值. 从左往右,从叶子到节点. 比如: 给定的二叉树是 {3,9,20,#,#,15,7}, 3 / \ 9 20 / \ 15 7 返回它从下 ...

  4. 102. Binary Tree Level Order Traversal 广度优先遍历

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

  5. LeetCode OJ:Binary Tree Level Order Traversal II(二叉树的层序遍历)

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

  6. 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 ...

  7. LeetCode 102. 二叉树的层次遍历(Binary Tree Level Order Traversal) 8

    102. 二叉树的层次遍历 102. Binary Tree Level Order Traversal 题目描述 给定一个二叉树,返回其按层次遍历的节点值. (即逐层地,从左到右访问所有节点). 每 ...

  8. [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 ...

  9. [LeetCode] Binary Tree Level Order Traversal 二叉树层序遍历

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

  10. [LeetCode] 102. Binary Tree Level Order Traversal 二叉树层序遍历

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

随机推荐

  1. Egret打包App 短暂黑屏解决方案 (Egret4.1.0)

    论坛已经有人解决:http://bbs.egret.com/forum.php?mod=viewthread&tid=30288&highlight=app%2B%E9%BB%91%E ...

  2. 【BZOJ4278】[ONTAK2015]Tasowanie 后缀数组

    [BZOJ4278][ONTAK2015]Tasowanie Description 给定两个数字串A和B,通过将A和B进行二路归并得到一个新的数字串T,请找到字典序最小的T. Input 第一行包含 ...

  3. 【BZOJ3943】[Usaco2015 Feb]SuperBull 最大生成树

    [BZOJ3943][Usaco2015 Feb]SuperBull Description Bessie and her friends are playing hoofball in the an ...

  4. C语言实现日历输出

    这个还是挺实用的.... 头文件: #ifndef MAIN_H #define MAIN_H #include "stdio.h" #include "math.h&q ...

  5. C#知识

    2018年10月29日 1.类可以定义的位置: (1)单独定义一个class,在program类的同一个文件内 (2)单独定义一个class,在program类的不同一个文件内 (3)类内定义clas ...

  6. Python开发【前端】:Ajax(一)

    Ajax Ajax即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术,AJAX = 异步 JavaScr ...

  7. sshd:root@notty解决方法

    sshd:root@notty解决方法 [复制链接]--http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=2050551 cat /e ...

  8. Linux资源使用配置文件 /etc/security/limits.conf

    Linux资源使用配置文件 /etc/security/limits.conf http://www.linuxidc.com/Linux/2012-05/59489.htm Linux就这个范儿P5 ...

  9. Openstack(四)Mysql主从

    4.1 安装mysql 4.1.1 安装依赖 # yum install vim gcc gcc-c++ wget autoconf  net-tools lrzsz iotop lsof iotop ...

  10. PAT 1090 Highest Price in Supply Chain[较简单]

    1090 Highest Price in Supply Chain(25 分) A supply chain is a network of retailers(零售商), distributors ...