python 怎么用代码实现二叉树判断叶子结点
时间: 2024-01-18 21:03:55 浏览: 77
可以使用递归的方式实现判断二叉树节点是否为叶子节点。
具体实现方式如下:
```python
class Node:
def __init__(self, value):
self.value = value
self.left = None
self.right = None
def is_leaf(node):
if node is None:
return False
if node.left is None and node.right is None:
return True
return False
# 示例二叉树
root = Node(1)
root.left = Node(2)
root.right = Node(3)
root.left.left = Node(4)
root.left.right = Node(5)
root.right.left = Node(6)
root.right.right = Node(7)
# 判断示例二叉树节点是否为叶子节点
print(is_leaf(root)) # False
print(is_leaf(root.left)) # False
print(is_leaf(root.right)) # False
print(is_leaf(root.left.left)) # True
print(is_leaf(root.left.right)) # True
print(is_leaf(root.right.left)) # True
print(is_leaf(root.right.right)) # True
```
输出结果为:
```
False
False
False
True
True
True
True
```
在这个示例中,我们定义了一个 `Node` 类来表示二叉树节点。`is_leaf` 函数用于判断节点是否为叶子节点。在函数中,我们首先检查给定的节点是否为空。如果是,我们返回 `False`。否则,我们检查节点是否具有左右子节点。如果没有,我们返回 `True`,否则我们返回 `False`。
阅读全文