[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   7Output: 5
Explanation: The smallest value is 2, the second smallest value is 5.

Example 2:

Input: 2/ \2   2Output: -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);}
}

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

  1. LeetCode刷题(61)~找出数组中的幸运数

    题目描述 在整数数组中,如果一个整数的出现频次和它的数值大小相等,我们就称这个整数为「幸运数」. 给你一个整数数组 arr,请你从中找出并返回一个幸运数. 如果数组中存在多个幸运数,只需返回 最大 的 ...

  2. LeetCode简单题之二叉树中第二小的节点

    题目 给定一个非空特殊的二叉树,每个节点都是正数,并且每个节点的子节点数量只能为 2 或 0.如果一个节点有两个子节点的话,那么该节点的值等于两个子节点中较小的一个. 更正式地说,即 root.val ...

  3. LeetCode 671. 二叉树中第二小的节点

    文章目录 1. 题目信息 2. 解题 2.1 递归查找 2.2 改循环 1. 题目信息 给定一个非空特殊的二叉树,每个节点都是正数,并且每个节点的子节点数量只能为 2 或 0.如果一个节点有两个子节点 ...

  4. leetcode刷题250天(65)——1823. 找出游戏的获胜者(约瑟夫环问题)

    解题思路: 每次都可以计算出失败者的位置和下一轮开始人的位置 不断删除.重新开始就能得到最后的获胜者 class Solution:def findTheWinner(self, n: int, k: ...

  5. leetcode刷题之树(三)

    翻转二叉树,感觉做二叉树的问题好像都是那一套公式,除了个别的问题解决不了,用上篇博客leetcode刷题之树(二)的模型基本可以解决.总体来说就是树基本都可以利用递归和迭代的方法去解决,在涉及到树的遍 ...

  6. java 算法之找出数组中第二大的数

    1.如果仅考虑实现功能而不考虑效率,可以先通过排序算法将数组排序,然后根据数组下标来访问数组中第二大的数,,最快的排序算法一般为快速排序算法,但是其时间复杂度为(nlogn),根据下标访问需要便利一遍 ...

  7. C#LeetCode刷题-字典树

    字典树篇 # 题名 刷题 通过率 难度 208 实现 Trie (前缀树) 48.6% 中等 211 添加与搜索单词 - 数据结构设计 39.9% 中等 212 单词搜索 II 27.9% 困难 33 ...

  8. C#LeetCode刷题-线段树

    线段树篇 # 题名 刷题 通过率 难度 218 天际线问题 32.7% 困难 307 区域和检索 - 数组可修改 42.3% 中等 315 计算右侧小于当前元素的个数 31.9% 困难 493 翻转对 ...

  9. LeetCode刷题:位运算(找不同 和 只出现一次的数字)

    1.常见的位运算 按位与&:(1&1=1,1&0=0,0&1=0,0&0=0); 按位或 | : (1 | 1=1,1 | 0=1,0 | 1=1,0 | 0= ...

最新文章

  1. ASP.NET虚拟主机安全漏洞解决方案
  2. python分析nginx日志,每分钟nginx请求超过10ms的比例
  3. 简单做了一个sina微博的MVC第三方登陆
  4. mongodb 分组聚合_MongoDB按键值对进行聚合/分组
  5. Struts2基础学习总结
  6. MATLAB工具箱介绍
  7. linux la 的使用方法,Linux简介及常用命令使用4--linux高级命令与技巧(示例代码)
  8. 美国教授描述未来学校,将颠覆现有教育模式
  9. Dom,JQuery
  10. 转载:ReferenceEquals, == , Equals 区别
  11. 【数据异常校验】格拉布斯准则(Grubbs Criterion)处理数据异常
  12. 印度IT行业普遍高薪-印度互联网泡沫判断
  13. 一分钟解决微信小程序截图(截屏问题)
  14. 安装部署Apache Doris集群
  15. php wps 读取word内容,关于PHP导出WORD带图片
  16. 从零开始学习区块链技术
  17. 计算机网络协议有时序,计算机网络协议.doc
  18. 南浔区跨境电子商务公共服务中心今日揭牌!
  19. minHash最小哈希
  20. 用soa搭建统一的电子政务平台

热门文章

  1. C++多态的好处和作用(用实例说话)
  2. Unity中初步使用Navmesh寻路系统
  3. linux 下 批量添加后缀名,Linux 下批量修改后缀名
  4. 《Edge Boxes: Locating Object Proposals from Edges》读后感~
  5. 服务研究之:San-Yih Hwang
  6. 自我认知测试软件,《自我认知测评》.pdf
  7. Java实现搜索在Bait游戏中的应用研究
  8. 极光IM系列之java后台集成
  9. 基于树莓派GPIO口和光电传感器的障碍物检测
  10. HDU2188 选拔志愿者题解