• 腾讯//二叉树的最大深度


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

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

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

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

        3
       / 
      9  20
        /  
       15   7

    返回它的最大深度 3 。

    方法一:

    /**
     * Definition for a binary tree node.
     * public class TreeNode {
     *     int val;
     *     TreeNode left;
     *     TreeNode right;
     *     TreeNode(int x) { val = x; }
     * }
     */
    class Solution {
        public int maxDepth(TreeNode root) {
            return root == null? 0:(1+Math.max(maxDepth(root.left),maxDepth(root.right)));
        }
    }
    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        int maxDepth(TreeNode* root) {
            if(!root)
                return 0;
            return 1+max(maxDepth(root->left), maxDepth(root->right));
        }
    };

    方法二:

    /**
     * Definition for a binary tree node.
     * public class TreeNode {
     *     int val;
     *     TreeNode left;
     *     TreeNode right;
     *     TreeNode(int x) { val = x; }
     * }
     */
    class Solution {
        public int maxDepth(TreeNode root) {
            if(root == null) return 0;
            int res = 0;
            Queue<TreeNode> q = new LinkedList<>();
            q.offer(root);
            while(!q.isEmpty()){
                ++res;
                int n = q.size();
                for(int i = 0; i < n; i++){
                    TreeNode t = q.poll();
                    if(t.left != null) q.offer(t.left);
                    if(t.right != null) q.offer(t.right);
                }
            }
            return res;
        }
    }
    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        int maxDepth(TreeNode* root) {
            if(!root) return 0;
            int res = 0;
            queue<TreeNode *> q;
            q.push(root);
            while(!q.empty()){
                res++;
                int n = q.size();
                for(int i = 0; i < n; i++){
                    TreeNode *t = q.front();
                    q.pop();
                    if(t->left) q.push(t->left);
                    if(t->right) q.push(t->right);
                }
            }
            return res;
        }
    };
  • 相关阅读:
    JUC 常用 4 大并发工具类是哪几个?(面试必问)
    rinkeby faucet rinkeby测试币水龙头
    JVM内存结构图
    String类常见面试题
    XX:+TraceClassLoading在eclipse中的用法
    fastthread 堆栈定位 jvm分析工具
    Mybatis工作原理
    构建者模式
    List、Set和Map的区别
    rpc和http的区别是什么 各自的优缺点有哪些
  • 原文地址:https://www.cnblogs.com/strawqqhat/p/10602453.html
Copyright © 2020-2023  润新知