1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-10-25 06:48:57 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
Files
leetcode-problemset/leetcode-cn/problem (Chinese)/树节点 [tree-node].html
2022-03-29 12:43:11 +08:00

63 lines
1.6 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>给定一个表&nbsp;<code>tree</code><strong>id</strong> 是树节点的编号,&nbsp;<strong>p_id</strong>&nbsp;是它父节点的&nbsp;<strong>id 。</strong></p>
<pre>+----+------+
| id | p_id |
+----+------+
| 1 | null |
| 2 | 1 |
| 3 | 1 |
| 4 | 2 |
| 5 | 2 |
+----+------+</pre>
<p>树中每个节点属于以下三种类型之一:</p>
<ul>
<li>叶子:如果这个节点没有任何孩子节点。</li>
<li>根:如果这个节点是整棵树的根,即没有父节点。</li>
<li>内部节点:如果这个节点既不是叶子节点也不是根节点。</li>
</ul>
<p>&nbsp;</p>
<p>写一个查询语句,输出所有节点的编号和节点的类型,并将结果按照节点编号排序。上面样例的结果为:</p>
<p>&nbsp;</p>
<pre>+----+------+
| id | Type |
+----+------+
| 1 | Root |
| 2 | Inner|
| 3 | Leaf |
| 4 | Leaf |
| 5 | Leaf |
+----+------+
</pre>
<p>&nbsp;</p>
<p><strong>解释</strong></p>
<ul>
<li>节点 &#39;1&#39; 是根节点,因为它的父节点是 NULL ,同时它有孩子节点 &#39;2&#39;&#39;3&#39;</li>
<li>节点 &#39;2&#39; 是内部节点,因为它有父节点 &#39;1&#39; ,也有孩子节点 &#39;4&#39;&#39;5&#39;</li>
<li>节点 &#39;3&#39;, &#39;4&#39;&#39;5&#39; 都是叶子节点,因为它们都有父节点同时没有孩子节点。</li>
<li>样例中树的形态如下:
<p>&nbsp;</p>
<pre> 1
/ \
2 3
/ \
4 5
</pre>
<p>&nbsp;</p>
</li>
</ul>
<p><strong>注意</strong></p>
<p>如果树中只有一个节点,你只需要输出它的根属性。</p>