数据结构-C语言递归实现树的前中后序遍历

本文展示了如何使用C语言实现树的数据结构,并提供了插入节点、打印树以及进行前序、中序、后序遍历的函数。通过示例代码详细解释了每个遍历方法的逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <stdio.h>
#include <stdlib.h>
typedef struct tree
{
	int number ; 
	struct tree *left  ; 
	struct tree *right ; 
}TREE;
//对树插入节点 
void insert_tree(TREE **header , int number)
{
    //创建一颗树 
	TREE *New = NULL ; 
	New = malloc(sizeof(TREE));
	if(NULL == New)
	   return ;
	//初始化树节点的值 
	New->number = number ; 
	//分别将左子树和右子树设置为空 
	New->left = NULL ; 
	New->right = NULL ; 
	TREE **link = header ; 
	TREE *cur ; 
	while(cur = *link)
	{ 
        //判断新插入的节点和之前的值之间谁大谁小
        //小的就放在左子树,大的就放到右子树 
		if(New->number < cur->number)
			//*link = cur->left ; 
			link = &(cur->left) ;
		else
			link = &(cur->right) ; 
	}
	*link = New ;
}
//打印树 
void print_tree(TREE *header , int lever)
{
	if(header == NULL)
		return ; 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Engineer-Bruce_Yang

谢谢您

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值