顺序存储二叉树实现先序遍历
时间: 2023-11-14 10:55:37 浏览: 160
要实现顺序存储二叉树的先序遍历,可以使用数组来表示二叉树的结构。假设数组的下标从0开始计数,根节点位于下标为0的位置。对于任意一个节点i,其左子节点的位置为2*i+1,右子节点的位置为2*i+2。
以下是一个示例代码,实现顺序存储二叉树的先序遍历:
```python
def preorder_traversal(tree, index=0):
if index >= len(tree) or tree[index] is None:
return
# 先访问当前节点
print(tree[index])
# 递归遍历左子树
preorder_traversal(tree, 2 * index + 1)
# 递归遍历右子树
preorder_traversal(tree, 2 * index + 2)
```
使用时,可以将二叉树以数组形式传入函数`preorder_traversal`。其中None表示空节点。
例如,对于二叉树[1, 2, 3, 4, None, 5, 6],可以按照先序遍历的顺序输出节点值:
```python
tree = [1, 2, 3, 4, None, 5, 6]
preorder_traversal(tree) # 输出结果为:1 2 4 3 5 6
```
注意,顺序存储二叉树适用于完全二叉树,如果是非完全二叉树,需要使用其他数据结构来表示。
相关问题
用顺序数组存储结构来存储一颗二叉树,编写c语言算法实现对该二叉树进行先序遍历,输出先序遍历序列。
假设二叉树结点的数据类型为 `int`,则顺序数组存储结构中,按照完全二叉树的方式存储二叉树结点,从根节点开始编号为1,假设数组名为 `arr`,则节点i的左子节点为 `arr[2*i]`,右子节点为 `arr[2*i+1]`,父节点为 `arr[i/2]`。
以下是基于顺序数组存储结构的先序遍历算法实现:
```c
#include <stdio.h>
#define MAXSIZE 100 // 数组最大长度
int arr[MAXSIZE] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; // 顺序数组存储结构
void preOrder(int i) {
if (i >= MAXSIZE) { // 超出数组范围
return;
}
if (arr[i] == 0) { // 空结点
return;
}
printf("%d ", arr[i]); // 输出结点数据
preOrder(2 * i); // 遍历左子树
preOrder(2 * i + 1); // 遍历右子树
}
int main() {
preOrder(1); // 从根节点开始遍历
return 0;
}
```
以上代码中,`preOrder()` 函数实现了对二叉树的先序遍历,从根节点开始遍历,输出每个结点的数据。如果当前结点超出了数组的范围,则返回;如果当前结点是空结点,则返回。在遍历左子树和右子树之前,先输出当前结点的数据。最后在 `main()` 函数中调用 `preOrder()` 函数,从根节点开始遍历整棵二叉树。
用顺序存储结构创建n个结点的二叉树,编写算法实现对该二叉树进行先序遍历,输出先序遍历序列。
假设二叉树的结点数据类型为 `ElemType`,则先序遍历的算法如下:
```c
void PreOrderTraverse(ElemType *tree, int index)
{
// 输出当前结点的值
printf("%c ", tree[index]);
// 遍历左子树
if (2 * index + 1 < n && tree[2 * index + 1] != '#') {
PreOrderTraverse(tree, 2 * index + 1);
}
// 遍历右子树
if (2 * index + 2 < n && tree[2 * index + 2] != '#') {
PreOrderTraverse(tree, 2 * index + 2);
}
}
```
其中,`tree` 是存储二叉树的数组,`index` 是当前结点在数组中的下标,`n` 是二叉树的结点数目。`#` 表示空结点。
遍历过程中,先输出当前结点的值,然后递归遍历左子树和右子树。注意要判断左子树和右子树是否存在,以及它们的下标是否越界。
阅读全文