根据给定的先序遍历序列建立二叉树,并对其进行中序遍历、计算叶子结点个数、计算树的深度
时间: 2023-06-05 09:47:20 浏览: 93
好的,根据先序遍历序列建立二叉树可以按照以下步骤进行:
1. 创建一个空的根节点
2. 将先序遍历序列中的第一个元素作为根节点的值
3. 如果先序遍历序列中下一个元素小于根节点的值,将其作为根节点的左子节点,否则作为右子节点
4. 重复步骤3直到遍历完整个序列
建立好二叉树后,可以进行以下操作:
1. 中序遍历:按照左子树、根节点、右子树的顺序遍历二叉树,即先遍历左子树,再访问根节点,最后遍历右子树
2. 计算叶子节点个数:叶子节点指没有子节点的节点,可以通过递归遍历二叉树,当遍历到叶子节点时累加计数器
3. 计算树的深度:树的深度指从根节点到叶子节点的最长路径,可以通过递归遍历二叉树,每递归一层深度加1,最终返回左右子树深度的较大值再加1即可。
希望这些信息对您有所帮助!
相关问题
编写二叉树的递归遍历算法,给定二叉树的扩展先序遍历序列,输出二叉树的先序遍历,中序遍历和后序遍历的结点序列和叶子结点和和结点个数的c语言代码
以下是对应的 C 语言代码:
```c
#include <stdio.h>
#include <stdlib.h>
typedef struct TreeNode {
int val;
struct TreeNode* left;
struct TreeNode* right;
} TreeNode;
// 创建一棵二叉树
TreeNode* createTree(int* pos) {
char* s = "AB##C##";
char ch = s[(*pos)++];
if (ch == '#') {
return NULL;
}
TreeNode* root = (TreeNode*)malloc(sizeof(TreeNode));
root->val = ch;
root->left = createTree(pos);
root->right = createTree(pos);
return root;
}
// 先序遍历
void preOrder(TreeNode* root) {
if (root == NULL) {
return;
}
printf("%c ", root->val);
preOrder(root->left);
preOrder(root->right);
}
// 中序遍历
void inOrder(TreeNode* root) {
if (root == NULL) {
return;
}
inOrder(root->left);
printf("%c ", root->val);
inOrder(root->right);
}
// 后序遍历
void postOrder(TreeNode* root) {
if (root == NULL) {
return;
}
postOrder(root->left);
postOrder(root->right);
printf("%c ", root->val);
}
// 计算叶子结点个数
int countLeaves(TreeNode* root) {
if (root == NULL) {
return 0;
}
if (root->left == NULL && root->right == NULL) {
return 1;
}
return countLeaves(root->left) + countLeaves(root->right);
}
// 计算结点个数
int countNodes(TreeNode* root) {
if (root == NULL) {
return 0;
}
return countNodes(root->left) + countNodes(root->right) + 1;
}
int main() {
int pos = 0;
TreeNode* root = createTree(&pos);
printf("先序遍历:");
preOrder(root);
printf("\n");
printf("中序遍历:");
inOrder(root);
printf("\n");
printf("后序遍历:");
postOrder(root);
printf("\n");
printf("叶子结点个数:%d\n", countLeaves(root));
printf("结点个数:%d\n", countNodes(root));
return 0;
}
```
1.构造一棵二叉树,打印出先序遍历、中序遍历、后序遍历的遍历序列。 前序遍历:ABCDEFG 中序遍历:DCEBAGF 后序遍历:DECBGFA 提示:先根据给定的树,写出此树的扩展先序遍历序列,然后根据此遍历序列建立二叉树。 2.选择一种遍历方式计算该树中叶子结点的个数,并打印出叶子结点。 3.编写一个层序遍历算法,利用队列结构按层次(同一层自左至右)输出二叉树中所有的结点。
好的,我会为您解答这三个问题。
1. 构造二叉树的过程如下:
首先,根据前序遍历序列,可以知道根节点为A;
其次,根据中序遍历序列,可以划分出左子树和右子树,左子树的中序遍历序列为DCEB,右子树的中序遍历序列为AGF;
然后,根据左子树的中序遍历序列,可以知道左子树的根节点为E,于是左子树的前序遍历序列为BED,左子树的后序遍历序列为DEB;
类似地,根据右子树的中序遍历序列,可以知道右子树的根节点为G,于是右子树的前序遍历序列为GFA,右子树的后序遍历序列为GFB;
最后,根据以上信息,可以构造出二叉树如下:
```
A
/ \
/ \
/ \
/ \
D G
/ \ \
E B F
/ \
C G
```
2. 计算叶子节点的个数可以使用后序遍历,遍历过程中统计叶子节点的个数,并打印出叶子节点。具体实现如下:
```python
class TreeNode:
def __init__(self, val):
self.val = val
self.left = None
self.right = None
def count_leaf(root):
if not root:
return 0
if not root.left and not root.right:
print(root.val)
return 1
return count_leaf(root.left) + count_leaf(root.right)
root = TreeNode('A')
root.left = TreeNode('D')
root.left.left = TreeNode('E')
root.left.right = TreeNode('B')
root.left.right.left = TreeNode('C')
root.right = TreeNode('G')
root.right.right = TreeNode('F')
print("叶子结点个数为:", count_leaf(root))
```
输出结果为:
```
E
C
G
叶子结点个数为: 3
```
3. 层序遍历可以使用队列来实现,具体实现如下:
```python
class TreeNode:
def __init__(self, val):
self.val = val
self.left = None
self.right = None
def level_order(root):
if not root:
return
queue = [root]
while queue:
node = queue.pop(0)
print(node.val)
if node.left:
queue.append(node.left)
if node.right:
queue.append(node.right)
root = TreeNode('A')
root.left = TreeNode('D')
root.left.left = TreeNode('E')
root.left.right = TreeNode('B')
root.left.right.left = TreeNode('C')
root.right = TreeNode('G')
root.right.right = TreeNode('F')
print("层序遍历序列为:")
level_order(root)
```
输出结果为:
```
层序遍历序列为:
A
D
G
E
B
F
C
```
阅读全文