leetcode刷题之 树(14)-递归:找出二叉树中第二小的节点

[LeetCode] Second Minimum Node In a Binary Tree 二叉树中第二小的结点

 

Given a non-empty special binary tree consisting of nodes with the non-negative value, where each node in this tree has exactly two or zero sub-node. If the node has two sub-nodes, then this node's value is the smaller value among its two sub-nodes.

Given such a binary tree, you need to output the second minimum value in the set made of all the nodes' value in the whole tree.

If no such second minimum value exists, output -1 instead.

Example 1:

Input: 
    2
   / \
  2   5
     / \
    5   7

Output: 5
Explanation: The smallest value is 2, the second smallest value is 5.

 

Example 2:

Input: 
    2
   / \
  2   2

Output: -1
Explanation: The smallest value is 2, but there isn't any second smallest value.

这道题让我们找二叉树中的第二小的结点值,并且给该二叉树做了一些限制,比如对于任意一个结点,要么其没有子结点,要么就同时有两个子结点,而且父结点值是子结点值中较小的那个,当然两个子结点值可以相等。那么直接上暴力搜索呗,根据该树的附加条件可知,根结点一定是最小的结点值first,那么我们只要找出第二小的值second即可,初始化为整型的最大值。然后对根结点调用递归函数,将first和second当作参数传进去即可。在递归函数中,如果当前结点为空,直接返回,若当前结点孩值不等于first,说明其肯定比first要大,然后我们看其是否比second小,或者等于second的话就更新second,然后对当前结点的左右子结点分别调用递归函数即可, 同时 设置一个修改次数mod变量来统计是否second产生了修改 如果没有修改过则表示节点值都相等的情况 参见代码如下:

注意特殊的情况[2, 2, 2]  对应mod 和   [2,2,2147483647]  root.val <= second

class Solution {
    private int second = Integer.MAX_VALUE;
    private int mod = 0;
    
    public int findSecondMinimumValue(TreeNode root) {
        help(root, root.val);
        if(mod == 0)
            return -1;
        return second;
    }  
    private void help(TreeNode root, int min){
        if(root == null)
            return;
        if(root.val > min && root.val <= second){
            second = root.val;
            mod++;
        }
        help(root.left, min);
        help(root.right, min);
    }
}

下面这种方法也是用递归来做的,不过现在递归函数有了返回值,在递归函数中,还是先判断当前结点是否为空,为空直接返回-1。然后就是看当前结点是否等于first,不等于直接返回当前结点值。如果等于,我们对其左右子结点分别调用递归函数,分别得到left和right。如果left和right其中有一个为-1了,我们取其中的较大值;如果left和right都不为-1,我们取其中的较小值返回即可,参见代码如下:

递归模型


        1 递归结束条件 也就是到底的情况
  
        2 递归函数中间代码
    
        3 递归函数返回结果

递归函数意义: 返回截止到节点时的最小值
    

class Solution {
    public int findSecondMinimumValue(TreeNode root) {
        return help(root, root.val);
    }
    private int help(TreeNode root, int first){
        //1 递归结束条件 也就是到底的情况
        if(root == null)
            return -1;
        if(root.val > first)
            return root.val;
        //2 递归函数中间代码
        int left = help(root.left, first);
        int right = help(root.right, first);
        
        //3 递归函数返回结果
        if(left == -1 || right == -1)
            return Math.max(left, right);
        return Math.min(left, right);
    
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值