671. 二叉树中第二小的节点
给定一个非空特殊的二叉树,每个节点都是正数,并且每个节点的子节点数量只能为 2
或 0
。如果一个节点有两个子节点的话,那么该节点的值等于两个子节点中较小的一个。
更正式地说,root.val = min(root.left.val, root.right.val)
总成立。
给出这样的一个二叉树,你需要输出所有节点中的第二小的值。如果第二小的值不存在的话,输出 -1
。
示例 1:
输入:root = [2,2,5,null,null,5,7]
输出:5
解释:最小的值是 2 ,第二小的值是 5 。
示例 2:
输入:root = [2,2,2]
输出:-1
解释:最小的值是 2, 但是不存在第二小的值。
提示:
- 树中节点数目在范围 [1, 25] 内
- 1 <= Node.val <= 231 - 1
- 对于树中每个节点 root.val == min(root.left.val, root.right.val)
方法一:广度优先搜索
思路
朴素的做法是先遍历整棵树,用一个 HashSet 把所有的值去重并保存起来,然后遍历 HashSet 找出第二小的值。
当然也可以在遍历树的同时就寻找第二小的值。这里采用「广度优先搜索」遍历整棵树,在遍历的过程中寻找第二小的值。
参考代码
public int findSecondMinimumValue(TreeNode root) {
int ret = -1, first = root.val;
Deque<TreeNode> deque = new LinkedList<>();
deque.add(root);
while (!deque.isEmpty()) {
int n = deque.size();
for (int i = 0; i < n; i++) {
root = deque.pop();
if (root.left == null) {
continue;
}
if (root.left.val > first && (ret == -1 || root.left.val < ret)) {
ret = root.left.val;
}
if (root.right.val > first && (ret == -1 || root.right.val < ret)) {
ret = root.right.val;
}
deque.push(root.left);
deque.push(root.right);
}
}
return ret;
}
执行结果