zoukankan      html  css  js  c++  java
  • N叉树的最大深度-DFS

    再看这道题之前,先来一道类似的简单题。

    题目:求二叉树的最大深度

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

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

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

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

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

    来源:leetcode
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    这道题思路很简单,因为是二叉树,有两个子节点,我们可以用递归依次求出左子树的深度和右子树的深度,然后两个进行比较,取最大的,得出的记过+1,因为还有根节点的那层。所以代码就好写了。

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

    再来看这道题,这道题是上面那道题的变形,由二叉树变成了N叉树。

    题目

    给定一个 N 叉树,找到其最大深度。

    最大深度是指从根节点到最远叶子节点的最长路径上的节点总数
    说明:
    树的深度不会超过 1000。
    树的节点总不会超过 5000。
    看他给出的N叉树的定义。

    class Node {
        public int val;
        public List<Node> children;//孩子节点是个集合
    
        public Node() {}
    
        public Node(int _val) {
            val = _val;
        }
    
        public Node(int _val, List<Node> _children) {
            val = _val;
            children = _children;
        }
    };
    

    要想求出N叉树的最大深度,就是求出N叉树的子节点中最大深度+1,那么求N叉树子节点有可变为求出当前节点的所有子节点中最大的深度。因此这道题可以通过DFS深度优先遍历来解决。

    class Solution {
        public int maxDepth(Node root) {
            if(root==null){
                return 0;
            }
            if(root.children==null){
                return 1;
            }
            int res = 0;
            //遍历当前节点下面的所有子节点,求出子节点中最大深度
            for(int i=0;i<root.children.size();i++){
                res = Math.max(res,maxDepth(root.children.get(i)));
            }
            // 返回子节点中最大深度+1
            return res+1;
        }
    }
    

    唉,以后还得多刷刷有关树的题目。

    “旅途“永无止境!

  • 相关阅读:
    A1035
    A1005
    A1073
    A1061
    A1058
    A1027
    A1019
    Java 操作临时文件创建与删除
    面试必会之HashMap源码分析
    springboot整合cxf框架启动报错
  • 原文地址:https://www.cnblogs.com/itjiangpo/p/14181306.html
Copyright © 2011-2022 走看看