Leetcode608. 树节点

本文介绍了一种使用SQL查询来确定树形结构中各节点类型的解决方案。通过具体案例展示了如何根据节点是否有子节点及父节点来判断其是否为根节点、内部节点或叶节点,并提供了两种实现方式:CASE表达式和IF条件语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Every day a leetcode

题目来源:608. 树节点

问题描述

给定一个表 tree,id 是树节点的编号, p_id 是它父节点的 id 。

+----+------+
| id | p_id |
+----+------+
| 1  | null |
| 2  | 1    |
| 3  | 1    |
| 4  | 2    |
| 5  | 2    |
+----+------+

树中每个节点属于以下三种类型之一:

叶子:如果这个节点没有任何孩子节点。
根:如果这个节点是整棵树的根,即没有父节点。
内部节点:如果这个节点既不是叶子节点也不是根节点。

写一个查询语句,输出所有节点的编号和节点的类型,并将结果按照节点编号排序。上面样例的结果为:

+----+------+
| id | Type |
+----+------+
| 1  | Root |
| 2  | Inner|
| 3  | Leaf |
| 4  | Leaf |
| 5  | Leaf |
+----+------+

解释

节点 ‘1’ 是根节点,因为它的父节点是 NULL ,同时它有孩子节点 ‘2’ 和 ‘3’ 。
节点 ‘2’ 是内部节点,因为它有父节点 ‘1’ ,也有孩子节点 ‘4’ 和 ‘5’ 。
节点 ‘3’, ‘4’ 和 ‘5’ 都是叶子节点,因为它们都有父节点同时没有孩子节点。
样例中树的形态如下:

		            	  1
		               	/   \
                      2       3
                    /   \
                  4       5

注意

如果树中只有一个节点,你只需要输出它的根属性。

SQL代码

代码1:CASE

# Write your MySQL query statement below
SELECT id,
    CASE 
        WHEN tree.id=(SELECT t.id FROM tree t WHERE t.p_id IS NULL)
            THEN 'Root'
        WHEN tree.id IN (SELECT t.p_id FROM tree t)
            THEN 'Inner'
        ELSE 'Leaf'
        END AS Type
FROM tree
ORDER BY id;

代码2:IF

# Write your MySQL query statement below
SELECT id,
    IF(ISNULL(tree.p_id),'Root',
    IF(tree.id IN (SELECT tree.p_id FROM tree),'Inner','Leaf')) AS Type
FROM tree
ORDER BY id;

结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

UestcXiye

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值