二叉树的三种遍历(双链表实现)以及递归思想的个人理解--C语言

二叉树

二叉树(Binary tree)是树形结构的一个重要类型。许多实际问题抽象出来的数据结构往往是二叉树形式,即使是一般的树也能简单地转换为二叉树,而且二叉树的存储结构及其算法都较为简单,因此二叉树显得特别重要。二叉树特点是每个节点最多只能有两棵子树,且有左右之分。所以实现二叉树的遍历用双链表比较简单。

实现一个数组的二叉树插入遍历

data_type arr[] = {35,45,23,44,33,65,13,54};

创建一个二叉树双链表

根据二叉树的特点,我们定义一个包含左右孩子和本身数据的结构体作为根结点

typedef int data_type;

typedef struct treeNode
{
	struct treeNode *lchild;
	struct treeNode *rchild;
	data_type data;
}tree;

写一个申请根节点的函数,返回申请到的空间的首地址

tree *createTree(data_type item)
{
	tree *pRoot = NULL;
	pRoot = (tree *)malloc(sizeof(tree));
	if(pRoot == NULL)
	{
		return NULL;
	}
	memset(pRoot,0,sizeof(tree));
	pRoot->data = item;

	return pRoot;
}

插入结点

插入结点时,我们要先判断插入的值和根结点值谁更大,比根结点大我们将他插入到左孩子中,否则插入到右孩子中

int insertTree(tree *pRoot,data_type item)
{
	tree *pNew = NULL;
	pNew = (tree *)malloc(sizeof(tree));
	if(pNew == NULL)
	{
		return -1;
	}
	memset(pNew,0,sizeof(tree));
	pNew->data = item;
	while(1)
	{
		
		if(pNew->data < pRoot->data)//插入左孩子处
		{
			if(pRoot->lchild != NULL)
			{
				pRoot = pRoot->lchild;
			}
			else
			{
				pRoot->lchild = pNew;
				return 0;
			}
		}
		else
		{
			if(pRoot->rchild != NULL)//插入右孩子处
			{
				pRoot = pRoot->rchild;
			}
			else
			{
				pRoot->rchild = pNew;
				return 0;
			}
		}
	}
}

三种遍历

二叉树的遍历分为以下三种:

  • 先序遍历:遍历顺序规则为【根左右】

  • 中序遍历:遍历顺序规则为【左根右】

  • 后序遍历:遍历顺序规则为【左右根】

利用递归思想,实现二叉树的遍历。会在末尾讲解二叉树的递归

前序遍历

//前序遍历
int preOrder(tree *pRoot)
{
	if(pRoot == NULL)
	{
		return -1;
	}
	//先访问根结点
	printf("%d ",pRoot->data);
	//访问左子树
	preOrder(pRoot->lchild);
	//访问右子树
	preOrder(pRoot->rchild);
}

中序遍历

//中序遍历
int inOrder(tree *pRoot)
{
	if(pRoot == NULL)
	{
		return -1;
	}
	inOrder(pRoot->lchild);
	printf("%d ",pRoot->data);
	inOrder(pRoot->rchild);
}

后序遍历

//后序遍历
int postOrder(tree *pRoot)
{
	if(pRoot == NULL)
	{
		return -1;
	}
	postOrder(pRoot->lchild);
	postOrder(pRoot->rchild);
	printf("%d ",pRoot->data);
}

运行结果

递归思想

拿我们的前序遍历来讲解

	if(pRoot == NULL)
	{
		return -1;
	}
	//先访问根结点
	printf("%d ",pRoot->data); // 1
	//访问左子树
	preOrder(pRoot->lchild); // 2
	//访问右子树
	preOrder(pRoot->rchild); // 3

接下来用一张自己画的图来详细说明
二叉树递归遍历思想
以上是我对递归思想的理解,如有错误请指正!

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

居合啊

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值