C++ | Leetcode C++题解之第111题二叉树的最小深度

题目:

题解:

cpp 复制代码
class Solution {
public:
    int minDepth(TreeNode *root) {
        if (root == nullptr) {
            return 0;
        }

        queue<pair<TreeNode *, int> > que;
        que.emplace(root, 1);
        while (!que.empty()) {
            TreeNode *node = que.front().first;
            int depth = que.front().second;
            que.pop();
            if (node->left == nullptr && node->right == nullptr) {
                return depth;
            }
            if (node->left != nullptr) {
                que.emplace(node->left, depth + 1);
            }
            if (node->right != nullptr) {
                que.emplace(node->right, depth + 1);
            }
        }

        return 0;
    }
};
相关推荐
历程里程碑3 分钟前
21:重谈重定义理解一切皆“文件“及缓存区
linux·c语言·开发语言·数据结构·c++·算法·缓存
wxin_VXbishe5 分钟前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·spring boot·python·spring·django·php
oldmao_200014 分钟前
第五章 C++内存模型与原子操作
c++
TracyCoder12317 分钟前
LeetCode Hot100(24/100)——21. 合并两个有序链表
算法·leetcode·链表
CSDN_RTKLIB26 分钟前
CMake制作动态库与静态库对比
c++
wWYy.29 分钟前
C++—集群聊天室(3)CMake详解
开发语言·c++
在路上看风景35 分钟前
16. 指针和引用的区别
c++
兩尛37 分钟前
45. 跳跃游戏 II
c++·算法·游戏
睡一觉就好了。40 分钟前
C++ 容器
开发语言·c++
怪谈爱好者CMZ1 小时前
【C++学习笔记】图论-最短路径Dijkstra算法
c++·笔记·学习