zoukankan      html  css  js  c++  java
  • leetcode刷题笔记一百零四题 二叉树的最大深度

    leetcode刷题笔记一百零四题 二叉树的最大深度

    源地址:104. 二叉树的最大深度

    问题描述:

    给定一个二叉树,找出其最大深度。

    二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。

    说明: 叶子节点是指没有子节点的节点。

    示例:
    给定二叉树 [3,9,20,null,null,15,7],

    3

    /
    9 20
    /
    15 7
    返回它的最大深度 3 。

    /**
    *本题亦可分为递归法和迭代法
    */
    //递归法
    /**
     * Definition for a binary tree node.
     * class TreeNode(var _value: Int) {
     *   var value: Int = _value
     *   var left: TreeNode = null
     *   var right: TreeNode = null
     * }
     */
    object Solution {
        def maxDepth(root: TreeNode): Int = {
            //当前结点为空,则返回0
            if (root == null) return 0、
            //否则返回左右子树的max高度+1
            return 1 + Math.max(maxDepth(root.left), maxDepth(root.right))
        }
    }
    
    //迭代法 基于BFS处理完一层将其左右子树加入,树高+1
    /**
     * Definition for a binary tree node.
     * class TreeNode(var _value: Int) {
     *   var value: Int = _value
     *   var left: TreeNode = null
     *   var right: TreeNode = null
     * }
     */
    import scala.collection.mutable 
    object Solution {
        def maxDepth(root: TreeNode): Int = {
            if (root == null) return 0
            val queue = new mutable.Queue[TreeNode]()
            var ans = 0
            queue.enqueue(root)
    
            while (queue.isEmpty == false){
                val queueSize = queue.size
                for (i <- 0  until queueSize){
                    val tempNode = queue.dequeue
                    if (tempNode.left != null) queue.enqueue(tempNode.left)
                    if (tempNode.right != null) queue.enqueue(tempNode.right)
                }
                ans += 1
            }
            return ans
        }
    }
    
  • 相关阅读:
    光学字符识别OCR-6 光学识别
    光学字符识别OCR-5 文本切割
    光学字符识别OCR-4
    光学字符识别OCR-3
    leetcode 7 Reverse Integer(水题)
    leetcode 1 Two Sum(查找)
    DFS的简单应用(zoj2110,poj1562)
    Havel-Hakimi定理(握手定理)
    zoj1360/poj1328 Radar Installation(贪心)
    饶毅:做自己尊重的人
  • 原文地址:https://www.cnblogs.com/ganshuoos/p/13434519.html
Copyright © 2011-2022 走看看