image.png

思路 递归

image.png

  1. public int minDepth(TreeNode root) {
  2. if(root==null)
  3. return 0;
  4. //1.左孩子和有孩子都为空的情况,说明到达了叶子节点,直接返回1即可
  5. if(root.left==null&&root.right==null)
  6. return 1;
  7. int minLeft = minDepth(root.left);
  8. int minRight = minDepth(root.right);
  9. //2.如果左孩子和由孩子其中一个为空,那么需要返回比较大的那个孩子的深度
  10. //这里其中一个节点为空,说明m1和m2有一个必然为0,所以可以返回m1 + m2 + 1;
  11. if(root.left==null||root.right==null)
  12. return minLeft+minRight+1;
  13. //3.最后一种情况,也就是左右孩子都不为空,返回最小深度+1即可
  14. return Math.min(minLeft,minRight)+1;
  15. }