c语言二叉树_linux学习第20节,二叉树的特性和插入、查询、删除等基本操作

前面几节较为详细的讨论了 linux 内核常用的链表、队列、映射等几种数据结构,本节将介绍C语言中另一种重要的数据结构——二叉搜索树(通常简称为BST),并且将一行一行写出相关的C语言代码。

二叉树的概念

树结构是一个多层的特定数据结构,每个节点之间通过指针连接(这点有些像链表),有 1 个或者 0 个入边,和 0 个或多个出边。对于二叉树,则每个节点最多只能由 2 个出边,一个典型的二叉树如下图所示。

07a42fd53e176dc3746614b4e9d4f5bc.png

二叉搜索树

如果二叉树的各个节点记录的数值是有序排列的,则该二叉树可称为“二叉搜索树”,它有以下三条性质:

  • 左子节点值都小于根节点值
  • 右子节点值都大于根节点值
  • 所有节点的子树也都是二叉搜索树
能够看出,二叉搜索树其实是“递归”定义的。

因此,二叉搜索树要求在插入数值时保证所有节点都是有序的,即左节点值始终小于父节点值,而右节点值始终大于父节点值。这样一来,二叉搜索树就特别适合存储需要快速检索的数据。

0a603de35e4321060037ef785ac54bda.png

使用C语言描述二叉搜索树

在 C语言中,常常用指针连接二叉树的各个节点,这就和链表很像,所以可以用如下结构体来描述一个二叉树,请看:

typedef struct __BINTREE{ struct __BINTREE* left; struct __BINTREE* right; int data;}BINTREE;

BINTREE 结构体非常简单,它有 left 和 right 两个指针,分别指向它的左右两个子节点,还有一个 data 成员用于记录数值。

将数值插入二叉搜索树

现在知道了二叉树的数据结构(BINTREE结构体),如果我想将某个数值插入二叉树,并且还要使其满足“二叉搜索树”的三条性质,该怎样编写C语言代码呢?

72a3e110f1bcc4ac6a553c3ced81016f.png

前面提到,二叉搜索树的三条性质其实是递归定义的,那么使用C语言的递归函数也就非常容易实现,请看:

int insert_node(BINTREE** pptree, int value){ if(NULL==(*pptree)){ (*pptree) = (BINTREE*)malloc(sizeof(BINTREE)); if(NULL==(*pptree)){ printf("insert %d failed for malloc failed
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值