Swift 二叉树的最大深度- LeetCode

作者: 韦弦Zhy | 来源:发表于2018-11-29 17:51 被阅读12次
    LeetCode

    题目: 二叉树的最大深度

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

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

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

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

        3
       / \
      9  20
        /  \
       15   7
    

    返回它的最大深度 3 。

    方案:

    分别求左右节点最大深度,左右节点又分别求左右节点的最大深度...递归解决

    代码:
    /**
     * Definition for a binary tree node.
     * public class TreeNode {
     *     public var val: Int
     *     public var left: TreeNode?
     *     public var right: TreeNode?
     *     public init(_ val: Int) {
     *         self.val = val
     *         self.left = nil
     *         self.right = nil
     *     }
     * }
     */
    class Solution {
        func maxDepth(_ root: TreeNode?) -> Int {
            if root == nil {
                return 0
            }
            return (1 + max(maxDepth(root?.left), maxDepth(root?.right)))
        }
    }
    
    用Swift开始学习算法中,在LeetCode中开始做初级算法这一章节,将做的题目在此做个笔记,希望有更好方法同学们cue我哦。

    相关文章

      网友评论

        本文标题:Swift 二叉树的最大深度- LeetCode

        本文链接:https://www.haomeiwen.com/subject/hxnfcqtx.html