zoukankan      html  css  js  c++  java
  • leetcode二叉树二叉树的最大深度 dfs、bfs

    package binarytree.maxDepth;
    
    import binarytree.untils.GenerateTreeNode;
    import binarytree.untils.TreeNode;
    
    import java.util.ArrayList;
    import java.util.LinkedList;
    import java.util.List;
    import java.util.Queue;
    
    /**
     * 104. 二叉树的最大深度
     * 给定一个二叉树,找出其最大深度。
     * <p>
     * 二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
     * <p>
     * 说明: 叶子节点是指没有子节点的节点。
     * <p>
     * 示例:
     * 给定二叉树 [3,9,20,null,null,15,7],
     * <p>
     * 3
     * / \
     * 9  20
     * /  \
     * 15   7
     * 返回它的最大深度 3 。
     */
    public class maxDepth {
        /**
         * 基本功 层序遍历即可
         *bfs
         * @param root
         * @return
         */
        public static int maxDepth(TreeNode root) {
            if (root == null) {
                return 0;
            }
            return levelOrder(root);
        }
    
        private static int levelOrder(TreeNode root) {
            List<List<Integer>> re = new ArrayList<>();
            Queue<TreeNode> queue = new LinkedList();
            queue.offer(root);
            while (!queue.isEmpty()) {
                List<Integer> res = new ArrayList<>();
                int size = queue.size();
    
                for (int i = 0; i < size; i++) {
                    TreeNode node = queue.poll();
                    res.add(node.val);
                    if (node.left != null) {
                        queue.add(node.left);
                    }
                    if (node.right != null) {
                        queue.add(node.right);
                    }
    
                }
                if (res.size() != 0) {
                    re.add(res);
                }
            }
            return re.size();
        }
    
    
        //dfs
        public static int maxDepth2(TreeNode root) {
            if (root == null) {
                return 0;
            }
            if(root.left == null && root.right==null){
                return 1;
            }
    
            int l = maxDepth2(root.left);
            int r = maxDepth2(root.right);
    
            if(root.left==null || root.right==null){
                return l+r+1;
            }
            return Math.max(l,r)+1;
        }
    
        public static void main(String[] args) {
            Integer[] nums = {1, 2, 3, 4, 5, 6, 7};
            TreeNode treeNode = GenerateTreeNode.generateTreeNode(nums);
    
            System.out.println(maxDepth2(treeNode));
        }
    }
    
    
  • 相关阅读:
    汇编笔记
    【BZOJ 1701】Cow School(斜率优化/动态凸包/分治优化)
    MS-DOS 6.22 +Vim+masm 汇编环境
    「NOIP2017」时间复杂度
    CCF 201809-3 元素选择器
    CCF 201712-3 Crontab
    ICPC NWERC2019~2020 Practice Contest
    蓝桥杯模拟赛3 F:等差等比有联系 公差公比求通项
    CCF 201509-3 模板生成系统
    CCF 201503-3 节日
  • 原文地址:https://www.cnblogs.com/xiaoshahai/p/15691563.html
Copyright © 2011-2022 走看看