zoukankan      html  css  js  c++  java
  • Minimum Depth of Binary Tree,求树的最小深度

    算法分析:递归和非递归两种方法。

    public class MinimumDepthofBinaryTree {
    	
    	//递归,树的最小深度,就是它左右子树的最小深度的最小值+1
    	public int minDepth(TreeNode root) {
            if(root == null)
            {
            	return 0;
            }
            int lmin = minDepth(root.left);
            int rmin = minDepth(root.right);
            if(lmin == 0 && rmin == 0)
            {
            	return 1;
            }
            if(lmin == 0)//左子树为空,右子树不为空,则最小深度为右子子树的最小深度+1
            {
            	return rmin + 1; 
            }
            if(rmin == 0)
            {
            	return lmin + 1;
            }
            return Math.min(lmin, rmin)+1;
        }
    	
    	
    	//非递归,按层遍历,找到第一个叶子结点
    	public int minDepth2(TreeNode root) {
    		if(root == null)
    		{
    			return 0;
    		}
    		ArrayList<TreeNode> list = new ArrayList<>();
    		int count = 1;//初始值为1
    		list.add(root);
    		while(!list.isEmpty())
    		{
    			ArrayList<TreeNode> temp = new ArrayList<>();
    			for (TreeNode node : list) {
    				if(node.left == null && node.right == null)//当节点左右子树都为空时,该节点为第一个叶子节点,该节点的深度即为树的最小深度
    				{
    					return count;
    				}
    				if(node.left != null)
    				{
    					temp.add(node.left);
    				}
    				if(node.right != null)
    				{
    					temp.add(node.right);
    				}
    			}
    			count ++;//按层遍历,每循环一次,就是一层,层数加1
    			list = temp;
    		}
    		return count;
        }
    }
    

      

  • 相关阅读:
    JavaScript—— scroolleftoffsetleft 系列的含义以及浏览器兼容问题
    GCD
    Treap
    快速* 模板
    线性筛素数
    珂朵莉树
    One Night
    长整数相加运算(内含减法)。。= =
    骑士周游 非完美版。。= =
    《Windows取证分析》
  • 原文地址:https://www.cnblogs.com/masterlibin/p/5911330.html
Copyright © 2011-2022 走看看