• Leetcode—104.二叉树的最大深度【简单】


    2023每日刷题(六)

    Leetcode—104.二叉树的最大深度

    在这里插入图片描述

    递归实现代码

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     struct TreeNode *left;
     *     struct TreeNode *right;
     * };
     */
    
    
    int maxDepth(struct TreeNode* root){
        if(!root) {
            return 0;
        }
        int left = maxDepth(root->left);
        int right = maxDepth(root->right);
        return (left > right ? left + 1: right+1);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    运行结果

    在这里插入图片描述

    BFS队列实现代码

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
     *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
     *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
     * };
     */
    class Solution {
    public:
        int maxDepth(TreeNode* root) {
            if(root == NULL) {
                return 0;
            }
            int ans = 0;
            queue<TreeNode*> qu;
            qu.push(root);
            while(!qu.empty()) {
                ans++;
                int n = qu.size();
                for(int i = 0; i < n; i++) {
                    TreeNode* p = qu.front();
                    qu.pop();
                    if(p->left != NULL) {
                        qu.push(p->left);
                    }
                    if(p->right != NULL) {
                        qu.push(p->right);
                    }
                }
            }
            return ans;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37

    运行结果

    在这里插入图片描述

    C语言BFS版实现代码

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     struct TreeNode *left;
     *     struct TreeNode *right;
     * };
     */
    #define MAXSIZE 10003
    int maxDepth(struct TreeNode* root) {
        if(root == NULL) {
            return NULL;
        }
        int front = 0, rear = 0;
        int len = 0;
        struct TreeNode** queue = (struct TreeNode**)malloc(sizeof(struct TreeNode *) * MAXSIZE);
        queue[rear++] = root;
        int ans = 0;
        while(front != rear) {
            len = rear - front;
            ans++;
            while(len > 0) {
                len--;
                struct TreeNode* tmp = queue[front++];
                if(tmp->left) {
                    queue[rear++] = tmp->left;
                }
                if(tmp->right) {
                    queue[rear++] = tmp->right;
                }
            }
        }
        return ans;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    运行结果

    在这里插入图片描述

    之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

  • 相关阅读:
    给yarn/npm包管理设置代理加速nodejs依赖下载的方法
    大二学生JavaScript实训大作业——动漫秦时明月7页 期末网页制作 HTML+CSS+JavaScript 网页设计实例 企业网站制作
    C语言——从头开始——深入理解指针(1)
    从四个角度全面认识 ChatGPT
    IT30--制造业数字化战略规划(论文1)
    怎么批量转换图片格式?这些方法帮助你一键转换
    Echarts 教程一
    C/C++内存管理
    Android学习-加载网络图片、沉浸式状态栏
    流程控制语句 流程控制开关
  • 原文地址:https://blog.csdn.net/qq_44631615/article/details/133972908