用C语言的递归写个二叉搜索树(二叉排序树)吧

不会递归的程序员不是好程序员,虽然鄙人尚未毕业,是个无知的大学生。但这追去真理的上进心不可小量。
二叉树的每一个节点,与其左右子树都可以组成一个二叉树,利用这思路,可以写个递归形式的二叉树。

#include<stdio.h>
#include<stdlib.h>

typedef struct treeNode
{
	int data;
	struct treeNode* LeftChild;
	struct treeNode* RightChild;
}*LPBST,*LPNode,Node;

//createNode这个函数可以自己画个图练习一下
//每一个指针都由指针域和数据域构成
LPNode createNode(int data)
{
	LPNode newNode = (LPNode)malloc(sizeof(Node));
	if (newNode != NULL)
	{
		newNode->data = data;
		newNode->LeftChild = NULL;
		newNode->RightChild = NULL;
	}
	return newNode;
}

LPBST InsertNode(LPBST tree, int data)
{
	if (tree == NULL)
	{
	//如果树为空,则创建二叉树
		tree = createNode(data);
	}
	else
	{
		if (tree->data > data)
		{
		//对比插入的数据和该节点的数据,
		//若小于节点数据则进入左子树,大于则进入右子树,并调用自身函数
		//如此递归下去
			tree->LeftChild = InsertNode(tree->LeftChild, data);
		}
		else if (tree->data < data)
		{
			tree->RightChild = InsertNode(tree->RightChild, data);
		}
	}
	return tree;
}

LPNode SearchNode(LPBST tree, int data)
{
	if (tree == NULL)
	{
		return NULL;
	}
	else
	{
		//对比搜索的数据和该节点的数据,
		//若小于节点数据则进入左子树,大于则进入右子树,并调用自身函数
		//如此递归下去
		if (tree->data > data)
		{
			return SearchNode(tree->LeftChild, data);
		}
		else if(tree->data < data)
		{
			return SearchNode(tree->RightChild, data);
		}
		else
		{
			return tree;
		}
	}
}

LPNode FindMin(LPBST tree)
{
	if (tree == NULL)
	{
		return NULL;
	}
	else
	{
	//左子树为空 ,则该数据是最小数据。
		if (tree->LeftChild == NULL)
		{
			return tree;
		}
		else
		{
		//左子树不为空,则继续进入左子树查找
			return FindMin(tree->LeftChild);
		}
	}
}

LPNode FindMax(LPBST tree)
{
	if (tree == NULL)
	{
		return NULL;
	}
	else
	{
	//与FindMin函数的道理相反
		if (tree->RightChild == NULL)
		{
			return tree;
		}
		else
		{
			return FindMax(tree->RightChild);
		}
	}
}

void MidOrderTralersal(LPBST tree)
{
	if (tree != NULL)
	{
		MidOrderTralersal(tree->LeftChild);
		printf("%d\t", tree->data);
		MidOrderTralersal(tree->RightChild);
	}
}

LPBST DeleteNode(LPBST tree, int data)
{
	LPNode tempNode;
	if (tree == NULL)
	{
		return NULL;
	}
	//前面的递归部分都是道理相同的,比较目标数据与节点然后进行操作
	else if (tree->data > data)
	{
		tree->LeftChild = DeleteNode(tree->LeftChild, data);
	}
	else if (tree->data < data)
	{
		tree->RightChild = DeleteNode(tree->RightChild, data);
	}
	else
	{
		if (tree->LeftChild && tree->RightChild)
		{
			//在右子树中找到最小节点填充到被删除节点
			tempNode = FindMin(tree->RightChild);
			tempNode->data = tree->data;
			//在删除的节点的右子树中删除最小元素
			tree->RightChild = DeleteNode(tree->RightChild, tree->data);	
		}
		else
		{
			tempNode = tree;
			//有右子树或者无子节点
			if (tree->LeftChild == NULL)
			{
				tree = tree->RightChild;
			}
			//有左子树或者无子节点
			else if (tree->RightChild == NULL)
			{
				tree = tree->LeftChild;
			}
			free(tempNode);
		}
	}
	return tree;
}

int main()
{
//记着初始化变量,不管是指针变量还是普通变量
	LPBST tree=NULL;
	int array[8] = { 4,76,24,99,57,30,13,169 };
	for (int i = 0; i < 8; i++)
	{
		tree = InsertNode(tree, array[i]);
	}
	MidOrderTralersal(tree);
	printf("\n");
	LPNode MinNode = FindMin(tree);
	LPNode MaxNode = FindMax(tree);
	LPNode positionNode = SearchNode(tree, 169);
	printf("%d\t%d\t%d\n", MinNode->data, MaxNode->data, positionNode->data);

	tree = DeleteNode(tree, 13);
	MidOrderTralersal(tree);
	system("pause");
	return 0;
}

这篇博客不求点赞,只是随笔(强烈暗示)

后续。。。。

鄙人在复习的时候突发奇想,为什么在查询中要return Search,而不是tree->LeftChild=Search(tree->LeftChild);
在尝试运行后,当把return语句改成了后者语句,会爆出:warning C4715: “SearchNode”: 不是所有的控件路径都返回值。虽然不是错误,但却是个不折不扣的bug,具体的解释在这里:
不是所有的控件路径都返回值

注:文末链接转载自博客园作者抱月听风,已在评论区通知该作者。

-----------------------------------------分割线---------------------------------------
图片奉上
在这里插入图片描述

2020年11月17日头脑一热新开了一个公众号,不知道叫啥名字,暂时叫做
“盛凯文”,围绕C语言,C++,数据结构,未来也许会添加人工智能,Python等栏目,
作为一个大学生,真心想和大家一起学习,写了将近两年文章,希望大家可以多多指教,我们共同进步!
在这里插入图片描述

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值