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;
        }
    }
    

      

  • 相关阅读:
    编写安全检测脚本
    编写监控脚本
    编写一键部署软件脚本
    awk扩展应用
    sed基本用法
    字符串截取及切割,正则表达式,expect预期交互
    For,while,case,shell循环结构
    mybatis使用associaton进行分步查询
    mybatis中封装结果集常见示例
    Mybatis获取数据库自增主键
  • 原文地址:https://www.cnblogs.com/masterlibin/p/5911330.html
Copyright © 2011-2022 走看看