您的位置:首页 > 理论基础 > 数据结构算法

【LeetCode-面试算法经典-Java实现】【199-Binary Tree Right Side View(从右边看二叉树)】

2017-06-12 08:25 691 查看

【199-Binary Tree Right Side View(从右边看二叉树】

【LeetCode-面试算法经典-Java实现】【全部题目文件夹索引】

代码下载【https://github.com/Wang-Jun-Chao】

原题

  Given a binary tree, imagine yourself standing on the right side of it, return the values of the nodes you can see ordered from top to bottom.

  For example:

  Given the following binary tree,

1            <---
/   \
2     3         <---
\     \
5     4       <---


  You should return [1, 3, 4].

题目大意

  给定一个二叉树,想象自己站在树的右边,返回从下到下你能看到的节点的值。

解题思路

  二叉树的层次遍历。每层依照从左向右的顺序依次訪问节点,(每一层取最右边的结点)

代码实现

树结点类

public class TreeNode {
int val;
TreeNode left;
TreeNode right;

TreeNode(int x) {
val = x;
}
}


算法实现类

public class Solution {

public List<Integer> rightSideView(TreeNode root) {
List<Integer> result = new LinkedList<>();

if (root != null) {
Deque<TreeNode> deque = new LinkedList<>();
// 当前层的结点数
int current = 1;
// 下一层的结点数
int next = 0;
TreeNode node;
deque.addLast(root);
while (deque.size() > 0) {
// 取第一个结点
node = deque.removeFirst();
current--;

// 加入非空的左结点
if (node.left != null) {
next++;
deque.addLast(node.left);
}

// 加入非空的右结点
if (node.right != null) {
next++;
deque.addLast(node.right);
}

// 假设当前层已经处理完了
if (current == 0) {
// 保存此层的最右一个结点值
result.add(node.val);
// 设置下一层的元素个数
current = next;
next = 0;
}
}
}

return result;
}
}


评測结果

  点击图片,鼠标不释放,拖动一段位置。释放后在新的窗体中查看完整图片。





特别说明

欢迎转载,转载请注明出处【http://blog.csdn.net/derrantcm/article/details/47970785

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐