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;
    }
};
相关推荐
量子炒饭大师8 小时前
【优化算法】双指针算法的「义体化」重构 ——【双指针】双指针算法中的指针是如何定义的?如何使用它进行一些简单的算法?
c++·算法·重构·优化算法·双指针
小辉同志8 小时前
62. 不同路径
c++·力扣·多维动态规划
arron88998 小时前
DebugView未打印日志原因
c++
hele_two8 小时前
SDL2高效画实心圆的算法(一)
c++·算法·图形渲染
AbandonForce10 小时前
哈希表(HashTable,散列表)个人理解
开发语言·数据结构·c++·散列表
mask哥10 小时前
力扣算法java实现汇总整理(下)
java·算法·leetcode
样例过了就是过了10 小时前
LeetCode热题100 编辑距离
数据结构·c++·算法·leetcode·动态规划
z2005093010 小时前
C++中位图和布隆过滤器的一些面试题
开发语言·c++
khalil102011 小时前
代码随想录算法训练营Day-46 动态规划13 | 647. 回文子串、516.最长回文子序列、动态规划总结
数据结构·c++·算法·leetcode·动态规划·回文子串·回文子序列
挨踢ren11 小时前
单例模式:C++实现与多线程安全
c++·设计模式