C语言实现笛卡尔树

本文介绍了如何使用C语言构建笛卡尔树。笛卡尔树是一种保持原始序列顺序并具有堆性质的二叉树。通过中序遍历笛卡尔树,仍可得到原序列。文章详细阐述了构建笛卡尔树的思路,包括新节点插入的判断和处理,并提供了具体的C语言代码实现。

先来回顾一下笛卡尔树的性质:笛卡尔树是这样一个二叉树,它能保持原序列的先后顺序,并且具备堆的性质。这里假设序列中无相等元素。

假设有一个序列{9,3,7,1,8,12,10,20,15,18,5},以此序列来建立一个笛卡尔树,则建好后的二叉树,中序访问该二叉树仍会得到原来的序列{9,3,7,1,8,12,10,20,15,18,5},且该二叉树还是一个堆(大根堆或小根堆)。以小根堆为例,则建成的笛卡尔树如图所示:

图源自维基百科

来说一下根据指定序列,建立笛卡尔树的思路:

因为新加入的节点在顺序上排在后面,所以只能在树的“右链”中寻找新节点应该插入的位置。(对右链操作的详细解释,可以看https://oi-wiki.org/ds/cartesian-tree/)那么怎么找到合适的位置?最简单的情况:新的节点的值大于右链中的叶子节点

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值