【数据结构与算法】二叉树——二叉树的最小深度
二叉树的最小深度
LeetCode:二叉树的最小深度
题目描述:
给定一个二叉树,找出其最小深度。
最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
说明: 叶子节点是指没有子节点的节点
示例:
给定二叉树?[3,9,20,null,null,15,7], 3 / 9 20 / 15 7 返回它的最小深度 ?2.
思想:
还是递归,没啥特别的
代码
我的第一遍代码:
public int minDepth(TreeNode root) { if(root==null) return 0; if(root.left==null&&root.right==null) return 1; if(root.left==null) return 1+minDepth(root.right); if(root.right==null) return 1+minDepth(root.left); return 1+Math.min(minDepth(root.left),minDepth(root.right)); }
优化之后:
class Solution { public int minDepth(TreeNode root) { if(root==null) return 0; int x=minDepth(root.right); int y=minDepth(root.left); if(x==0||y==0) return x+y+1; return Math.min(x,y)+1; } }
if(x == 0||y==0) return x+y+1; 非常妙
相关推荐
shenwenjie 2020-09-24
xiesheng 2020-08-02
mingyunxiaohai 2020-07-28
Cypress 2020-07-08
alicelmx 2020-06-16
Cypress 2020-06-28
Dyancsdn 2020-06-27
Masimaro 2020-06-21
waitwolf 2020-06-21
Jasmineyaoyao 2020-06-16
OldBowl 2020-06-16
Masimaro 2020-06-14
waitwolf 2020-06-08
nurvnurv 2020-06-05
ustbfym 2020-06-04
ziruoxiangyi 2020-06-03
范范 2020-06-03
Jasmineyaoyao 2020-05-31