建立一个二叉树;按先序、中序、后序遍历二叉树(三种递归算法和中序遍历的非递归算法)
时间: 2024-06-01 20:13:42 浏览: 136
好的,让我来回答你的问题。
首先,建立一个二叉树的方法有很多种,我给你讲一下其中的一种。
假设你要建立一个二叉树,先确定根节点,然后将其他节点按照大小关系插入到树上,左边节点为小于父节点的数,右边节点为大于父节点的数。这样建立出的二叉树称作二叉查找树。
下面,我们来介绍三种递归算法和中序遍历的非递归算法,可以实现对二叉树的先序、中序、后序遍历。
先序遍历:
1. 访问根节点。
2. 遍历左子树。
3. 遍历右子树。
中序遍历:
1. 遍历左子树。
2. 访问根节点。
3. 遍历右子树。
后序遍历:
1. 遍历左子树。
2. 遍历右子树。
3. 访问根节点。
中序遍历的非递归算法:
中序遍历的非递归算法是通过使用栈来模拟递归实现的。
1. 定义一个空栈和一个指向根节点的指针cur。
2. 如果cur不为空或栈不为空,则重复以下操作:
a. 如果cur不为空,将cur压入栈中,并将cur指向其左儿子。
b. 否则,弹出栈顶元素,访问该元素,并将指针cur指向该元素的右儿子。
至此,我已经回答了你的问题。如果你还有其他问题,可以继续问我。
相关问题
请用C语言写出程序:输入字符序列,建立二叉树;按先序中序后序遍历二叉树(三种递归算法和中序遍历的非递归算法)
```c
#include <stdio.h>
#include <stdlib.h>
//定义二叉树结构体
struct TreeNode {
char data;
struct TreeNode* left;
struct TreeNode* right;
};
//根据输入的字符序列建立二叉树
struct TreeNode* createBinaryTree() {
char ch;
scanf("%c", &ch);
if (ch == '#') {
return NULL;
}
struct TreeNode* root = (struct TreeNode*)malloc(sizeof(struct TreeNode));
root->data = ch;
root->left = createBinaryTree();
root->right = createBinaryTree();
return root;
}
//先序遍历二叉树(递归算法)
void preOrderTraversalRecursive(struct TreeNode* root) {
if (root == NULL) {
return;
}
printf("%c ", root->data);
preOrderTraversalRecursive(root->left);
preOrderTraversalRecursive(root->right);
}
//中序遍历二叉树(递归算法)
void inOrderTraversalRecursive(struct TreeNode* root) {
if (root == NULL) {
return;
}
inOrderTraversalRecursive(root->left);
printf("%c ", root->data);
inOrderTraversalRecursive(root->right);
}
//后序遍历二叉树(递归算法)
void postOrderTraversalRecursive(struct TreeNode* root) {
if (root == NULL) {
return;
}
postOrderTraversalRecursive(root->left);
postOrderTraversalRecursive(root->right);
printf("%c ", root->data);
}
//中序遍历二叉树(非递归算法)
void inOrderTraversal(struct TreeNode* root) {
struct TreeNode* stack[100];
int top = -1;
struct TreeNode* p = root;
while (p != NULL || top != -1) {
if (p != NULL) {
stack[++top] = p;
p = p->left;
} else {
p = stack[top--];
printf("%c ", p->data);
p = p->right;
}
}
}
int main() {
printf("请输入字符序列,以#表示空节点:\n");
struct TreeNode* root = createBinaryTree();
printf("先序遍历结果:");
preOrderTraversalRecursive(root);
printf("\n中序遍历结果:");
inOrderTraversalRecursive(root);
printf("\n后序遍历结果:");
postOrderTraversalRecursive(root);
printf("\n中序遍历结果(非递归算法):");
inOrderTraversal(root);
return 0;
}
```
建立二叉树,先序中序后序遍历
二叉树是一种树形结构,每个节点最多有两个子节点。建立二叉树的过程可以通过前序遍历和中序遍历序列来实现。具体步骤如下:
1. 从前序遍历序列中取出第一个元素作为根节点。
2. 在中序遍历序列中找到根节点的位置,将中序遍历序列分为左子树和右子树两部分。
3. 根据左子树和右子树的元素个数,在前序遍历序列中分别找到左子树和右子树的元素,递归地建立左子树和右子树。
4. 输出二叉树的先序遍历序列,即根节点->左子树->右子树。
5. 输出二叉树的中序遍历序列,即左子树->根节点->右子树。
6. 输出二叉树的后序遍历序列,即左子树->右子树->根节点。
7. 统计二叉树的叶子节点数,即没有子节点的节点数。
除了递归算法,还可以使用非递归算法实现二叉树的遍历。具体实现方法可以参考引用中的内容。
阅读全文