面试必刷TOP101:41、输出二叉树的右视图
原创
©著作权归作者所有:来自51CTO博客作者敏儿好学不耻下问的原创作品,请联系作者获取转载授权,否则将追究法律责任
题解
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
* 求二叉树的右视图
* @param preOrder int整型一维数组 先序遍历
* @param inOrder int整型一维数组 中序遍历
* @return int整型一维数组
*/
public int[] solve (int[] preOrder, int[] inOrder) {
// write code here
List<Integer> result = new ArrayList<>();
if (preOrder.length < 1 || preOrder.length != inOrder.length) {
return null;
}
// 根据前序遍历和中序遍历构造二叉树
TreeNode root = buildTree(preOrder, 0, preOrder.length - 1, inOrder, 0, inOrder.length - 1);
if (root == null) {
return null;
}
// 使用迭代法寻找二叉树的最右侧节点
Deque<TreeNode> queue = new LinkedList<>();
queue.addLast(root);
while (!queue.isEmpty()) {
// 求出每层节点的数量
int size = queue.size();
for (int i = 0; i < size; i++) {
TreeNode node = queue.removeFirst();
// size - 1即为最右侧节点,加入到result结果列表中
if (i == size - 1) {
result.add(node.val);
}
if (node.left != null) {
queue.addLast(node.left);
}
if (node.right != null) {
queue.addLast(node.right);
}
}
}
return result.stream().mapToInt(x -> x).toArray();
}
// 根据前序遍历和中序遍历构造二叉树
public TreeNode buildTree(int[] preOrder, int preStart, int preEnd, int[] inOrder, int inStart, int inEnd) {
if (preStart > preEnd || inStart > inEnd) {
return null;
}
int root_val = preOrder[preStart];
TreeNode root = new TreeNode(root_val);
int index = 0;
for (index = 0; index < inOrder.length; index++) {
if (inOrder[index] == root_val) {
break;
}
}
int left_length = index - inStart;
root.left = buildTree(preOrder, preStart + 1, preStart + left_length, inOrder, inStart, index - 1);
root.right = buildTree(preOrder, preStart + left_length + 1, preEnd, inOrder, index + 1, inEnd);
return root;
}
}