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 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>的更多相关文章
- LeetCode之Binary Tree Level Order Traversal 层序遍历二叉树
Binary Tree Level Order Traversal 题目描述: Given a binary tree, return the level order traversal of its ...
- 102. Binary Tree Level Order Traversal ------层序遍历
Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to righ ...
- LeetCode 107 Binary Tree Level Order Traversal II(二叉树的层级顺序遍历2)(*)
翻译 给定一个二叉树,返回从下往上遍历经过的每一个节点的值. 从左往右,从叶子到节点. 比如: 给定的二叉树是 {3,9,20,#,#,15,7}, 3 / \ 9 20 / \ 15 7 返回它从下 ...
- 102. Binary Tree Level Order Traversal 广度优先遍历
Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...
- 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 ...
- 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 ...
- LeetCode 102. 二叉树的层次遍历(Binary Tree Level Order Traversal) 8
102. 二叉树的层次遍历 102. Binary Tree Level Order Traversal 题目描述 给定一个二叉树,返回其按层次遍历的节点值. (即逐层地,从左到右访问所有节点). 每 ...
- [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 ...
- [LeetCode] Binary Tree Level Order Traversal 二叉树层序遍历
Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...
- [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, ...
随机推荐
- {sharepoint}提升 SharePoint 代码执行权限
提升 SharePoint 代码执行权限 关于如何提升 SharePoint 代码执行权限及相关知识介绍的文章我们园子里有很多, 这里给出其中两篇文章的链接,就不再啰嗦了. http://www.cn ...
- ios 更改全局UINavigationBar的背景图片以及通知栏颜色
1.更改UINavigationController push 到另一个界面返回按钮的title self.navigationController.navigationBar.topItem.bac ...
- 【Android】Could not find XXX.apk!的解决方法
昨天在Eclipse中导入一个Android工程后点击运行时出现了Could not find XXX.apk!的错误信息,具体错误提示如下: 到网上搜了好多方法,挨个尝试,最后都没解决但是,重启 ...
- jfinal的controller默认访问的方法是什么
index()方法: 如: @Controller("/test/exam")public class TestController 如下请求请求:http://localhost ...
- <sourceDirectory>src/main/java</sourceDirectory> mvn 配置 包路径
<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven ...
- teamviewer and openconnect-gp (globalprotect) in ubuntu
wget https://download.teamviewer.com/download/teamviewer_i386.deb sudo dpkg -i teamviewer_i386.deb a ...
- python采用pika库使用rabbitmq总结,多篇笔记和示例(转)
add by zhj:作者的几篇文章参考了Rabbitmq的Tutorials中的几篇文章. 原文:http://www.01happy.com/python-pika-rabbitmq-summar ...
- Idea的注入和自动编译配置
实时编译: 第二个(防止编译时Autowired报错): 修改成:
- 【python】BeautifulSoup的应用
from bs4 import BeautifulSoup#下面的一段HTML代码将作为例子被多次用到.这是 爱丽丝梦游仙境的 的一段内容(以后内容中简称为 爱丽丝 的文档): html_doc = ...
- python 定义类 学习1
此时的d1就是类Dog的实例化对象 实例化,其实就是以Dog类为模版,在内存里开辟一块空间,存上数据,赋值成一个变量名 # 定义类模板 class dog(object): # 定义类的方法功能 # ...