二叉树建立一个先序序列(递归实现)

二叉树建立一个先序序列(递归实现)

  1. 0代表空树
  2. 注意当输入叶子节点左右子树都为空树 ,这时需要在后面输入0 0(两个0)
  3. 注意理解递归方法,找到入口和出口
#include<stdio.h>
#include<stdlib.h>
typedef struct node{
	int data;
	struct node *lchild,*rchild;
	
} node,*tree;
tree creat(){
	tree t;
	int ch;
	scanf("%d",&ch);
	if(ch==0)
	{
	t=NULL;}
	else{
		t=(tree)malloc(sizeof(node));
		t->data=ch;
		t->lchild=creat();
		t->rchild=creat();
	}
	return t;
}
void print(tree t)
{

	if(t) 
	
	{
		printf(" %d",t->data);
		print(t->lchild);
		print(t->rchild);
	}
}
int main()
{   tree t;
	printf("请输入数据创建二叉树");
	t=creat();
		printf("先序序列为:");
	print(t);
	return 0;
}

在这里插入图片描述

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于满二叉树,可以通过后序序列转换为先序序列方法如下: 1. 后序序列的最后一个元素是根节点。 2. 在后序序列中,根节点前面的元素都是根节点的子节点。 3. 在先序序列中,子节点的顺序是先左后右。 4. 所以,在后序序列中找到根节点后,可以将后序序列的剩余部分分成两部分,一部分是左子树的后序序列,一部分是右子树的后序序列。 5. 分别对左右子树进行递归处理,即可得到左右子树的先序序列。 6. 将根节点加在先序序列的最前面,再加上左子树的先序序列和右子树的先序序列,即为整个二叉树先序序列。 以下是一个示例代码实现(使用Python): ```python def postorder_to_preorder(postorder): if not postorder: return [] root = postorder[-1] # 后序序列的最后一个元素是根节点 left_postorder = [] right_postorder = [] # 找到左子树和右子树的后序序列 for num in postorder[:-1]: if num < root: left_postorder.append(num) else: right_postorder.append(num) # 递归处理左右子树,得到先序序列 left_preorder = postorder_to_preorder(left_postorder) right_preorder = postorder_to_preorder(right_postorder) # 返回整个二叉树先序序列 return [root] + left_preorder + right_preorder # 示例调用 postorder = [4, 5, 2, 6, 7, 3, 1] preorder = postorder_to_preorder(postorder) print(preorder) ``` 输出结果为:[1, 2, 4, 5, 3, 6, 7] 希望能够帮助到你!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值