zoukankan      html  css  js  c++  java
  • [LeetCode#104, 111]Maximum Depth of Binary Tree, Minimum Depth of Binary Tree

    The problem 1:

    Given a binary tree, find its maximum depth.

    The maximum depth is the number of nodes along the longest path from the root node down to the farthest leaf node.

    My analysis:

    The recursion solution for this problem is very elegant!
    It include some skills we usually use in implenting recursive program for tree.
    1. the base case for tree traversal is the leaf node's empty child(null), not the leaf node itself.

    if (cur_root == null)
        return 0;

    2. when we calculate the path from current node to the leaf node, we calculate it from bottom to surface. At each node, we plus one, and return it to previous level recursion.
    3. We use Math.math() function to get the longest path for either sub-tree.

    return Math.max(helper(cur_root.left), helper(cur_root.right)) + 1; 

    My solution:

    public class Solution {
        public int maxDepth(TreeNode root) {
            return helper(root);
        }
        
        private int helper(TreeNode cur_root) {
            
            if (cur_root == null)
                return 0;
            
            return Math.max(helper(cur_root.left), helper(cur_root.right)) + 1; 
        }
    }

    The problem2: 

    Given a binary tree, find its minimum depth.

    The minimum depth is the number of nodes along the shortest path from the root node down to the nearest leaf node.

    My analysis:

    This problem is easy, but it differs a little with the previous problem: finding maximum path.
    In this problem, we need to tackle with the "leaf node case" very carefully.
    What's a leaf node?
    A leaf node must has no left child or right child. We should mix this case with situation that a node has only one child. Some errors I have commited to solve the problem.
    1. Directly return the minimum path among left-sub tree and right-sub tree. Apparently this is not right, what if a tree has only one left sub-tree with a length of 6?

    return Math.min(left_min, right_min) + 1;

    2. To fix the problem, I have tried to check if a node is a leaf node in each recursion. 

    private int helper(TreeNode cur_root) {
        if (cur_root == null)
            return 0;
        if (cur_root.left == null && cur_root.right == null) 
            return 1;
            ...
        return Math.min(left_min, right_min) + 1;
    }

    But this still does not work, because we must keep the checking condition "if (cur_root == null)". (if a node has only one child, the empty child must be tackled). Then the solution would aslo suffer from the wrong judgement as previous one.

    Fix:
    How about check if the current node has one child or two, then tackle and return the value respectively.
    1. check if the current node with only one child.
    Note: iff current node is a leaf node, the following stataments can still tackle it.

    if (left_min == 0)
        return right_min + 1;
    
    if (right_min == 0)
        return left_min + 1;

    2. if the current node with two children. 

    return Math.min(left_min, right_min) + 1;
    public class Solution {
        public int minDepth(TreeNode root) {
            
            if (root == null)
                return 0;
                
            return helper(root);
        }
        
        private int helper(TreeNode cur_root) {
            if (cur_root == null)
                return 0;
            
            int left_min = helper(cur_root.left);
            int right_min = helper(cur_root.right);
            
            if (left_min == 0)
                return right_min + 1;
            
            if (right_min == 0)
                return left_min + 1;
            
            return Math.min(left_min, right_min) + 1;
        }
    }
  • 相关阅读:
    请简单说一下你了解的端口及对应的服务?
    地址解析协议ARP和逆地址解析协议RARP
    IP地址分类
    OSI分层和五层协议
    对象如何晋升到老年代?
    JVM 垃圾回收机制,何时触发 MinorGC 等操作
    什么是引用?
    类加载机制
    Solaris10怎么创建flash archive
    RPC: program not registered (ZT)
  • 原文地址:https://www.cnblogs.com/airwindow/p/4216027.html
Copyright © 2011-2022 走看看