抱歉,您的浏览器无法访问本站
本页面需要浏览器支持(启用)JavaScript
了解详情 >

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

最小深度是从根节点到最近叶子节点的最短路径上的节点数量。


思路

  • 层序遍历,当出现首个没有左、右子树的节点时,该节点为首个叶子节点,其拥有最短深度。

学习点

代码

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
class Solution {
public:
int minDepth(TreeNode* root) {
int depth = 0;
queue<TreeNode*> qe;
if (root)
qe.push(root);
while (!qe.empty())
{
int node_num = qe.size();
for (int i = 0; i < node_num; i++)
{
auto tmp = qe.front();
qe.pop();

// 如果没有左右子树,则该节点为叶子节点,为最短深度
if (!tmp->left && !tmp->right)
return depth + 1;
else
{
if (tmp->left)
qe.push(tmp->left);
if (tmp->right)
qe.push(tmp->right);
}
}
++depth;
}

return depth;
}
};