LeetCode Java刷题笔记—199. 二叉树的右视图
Posted 刘Java
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode Java刷题笔记—199. 二叉树的右视图相关的知识,希望对你有一定的参考价值。
给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。
中等难度。这道题所谓的右视图,实际上就是求二叉树的每一层的最右侧节点。那么最简单的是我们使用从右到左的BFS层序遍历即可,获取每一层的第一个节点并加入结果集合。
public List<Integer> rightSideView(TreeNode root)
LinkedList<Integer> res = new LinkedList<>();
if (root == null)
return res;
LinkedList<TreeNode> queue = new LinkedList<>();
queue.addLast(root);
while (!queue.isEmpty())
int size = queue.size();
for (int i = 0; i < size; i++)
root = queue.removeFirst();
//第一个元素
if (i == 0)
res.addLast(root.val);
//从右到左中序遍历
if (root.right != null)
queue.addLast(root.right);
if (root.left != null)
queue.addLast(root.left);
return res;
另一种方式是使用DFS深度优先遍历,同样对于每一层的第一个节点加入结果集即可。
List<Integer> res = new ArrayList<>();
public List<Integer> rightSideView(TreeNode root)
dfs(root, 0);
return res;
void dfs(TreeNode root, int depth)
if (root == null)
return;
//如果当前层深度等于结果集数量,则说明当前节点是当前层的最右节点
if (depth == res.size())
res.add(root.val);
depth++;
dfs(root.right, depth);
dfs(root.left, depth);
以上是关于LeetCode Java刷题笔记—199. 二叉树的右视图的主要内容,如果未能解决你的问题,请参考以下文章