解题思路:
刚开始想到的就是利用回溯,树的最小深度等于树的左右子树的最小深度+1;
根据这个想法,写出解题算法
public class Solution { public int run(TreeNode root) { TreeNode node = root; //递归的边界条件 如果当前节点为null 高度为0 if(node == null) return 0; //递归的边界条件 如果当前节点是叶子节点(左右子树都为null),高度是1 if(node.left == null && node.right == null){ return 1; } //否则 左右节点有值 当前节点高度(只看当前节点)为1+ 那个不为null的子树的高度,因此为max if(node.left == null || node.right == null){ return 1 + Math.max(run(node.left), run(node.right)); } //最后是都不为空 1+左右子树的最小高度 return 1 + Math.min(run(node.left), run(node.right)); } }
另一种非递归的方法是层序遍历,从根节点开始,从上往下,利用一个队列存放需要遍历的节点,
代码:
public int run(TreeNode root) { if(root ==null) return 0; Queue<TreeNode> queue = new LinkedList<>(); queue.offer(root); int depth = 0;//当前树的深度 while(!queue.isEmpty()){ int size = queue.size(); //这个地方是关键,获取当前层需要遍历的节点个数 for(int i = 0; i < size; i++){ TreeNode current = queue.poll(); if(current.left == null && current.right == null) //如果左右子树都为空 return 1 + depth; if(current.left != null){ queue.offer(current.left); } if(current.right != null){ queue.offer(current.right); } } depth++; } return depth; }