- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
图解数据结构9_左偏树.
十三、左偏树(Leftist Tree)
树这个数据结构内容真的很多,上一节所讲的二叉堆,其实就是一颗二叉树,这次讲的左偏树(又叫“左翼堆”),也是树。
二叉堆是个很不错的数据结构,因为它非常便于理解,而且仅仅用了一个数组,不会造成额外空间的浪费,但它有个缺点,那就是很难合并两个二叉堆,对于“合并”,“拆分”这种操作,我觉得最方面的还是依靠指针,改变一下指针的值就可以实现,要是涉及到元素的移动,那就复杂一些了。
左偏树跟二叉堆比起来,就是一棵真正意义上的树了,具有左右指针,所以空间开销上稍微大一点,但却带来了便于合并的便利。BTW:写了很多很多的程序之后,我发觉“空间换时间”始终是个应该考虑的编程方法。:)
左偏左偏,给人感觉就是左子树的比重比较大了,事实上也差不多,可以这么理解:左边分量重,那一直往右,就一定能最快地找到可以插入元素的节点了。所以可以这样下个定义:左偏树就是对其任意子树而言,往右到插入点的距离(下面简称为“距离”)始终小于等于往左到插入点的距离,当然了,和二叉堆一样,父节点的值要小于左右子节点的值。
如果节点本身不满,可插入,那距离就为0,再把空节点的距离记为-1,这样我们就得出:父节点的距离 = 右子节点距离 + 1,因为右子节点的距离始终是小于等于左子节点距离的。我把距离的值用蓝色字体标在上图中了。
左偏树并一定平衡,甚至它可以很不平衡,因为它其实也不需要平衡,它只需要像二叉堆那样的功能,再加上合并方便,现在来看左偏树的合并算法,如图:
这种算法其实很适合用递归来做,但我还是用了一个循环,其实也差不多。对于左偏树来说,这个合并操作是最重要最基本的了。为什么?你看哦:Enqueue,我能不能看作是这个左偏树的root和一个单节点树的合并?而Dequeue,我能不能看作是把root节点取出来,然后合并root的左右子树?事实上就是这样的,我提供的代码就是这样干的。
Conclusion:左偏树比同二叉堆的优点就是方便合并,缺点是编程复杂度略高(也高不去哪),占用空间稍大(其实也大不去哪)。附上代码,老样子了,单个文件,直接调试的代码,零依赖零配置,一看就懂,代码虽然不算完美,但作为演示和学习,是足够了。
#include?stdio.h//?TreeNode//////////////////////////////////////////////////////////////////////////struct?TreeNode?{????TreeNode(int?iVal)????{????????m_iData?=?iVal;????????m_iDistance?=?0;????????m_pLeft?=?0;????????m_pRight?=?0;????}????~TreeNode()????{????}????void?SwapLeftRight()????{????????TreeNode?*pTmp?=?m_pLeft;????????m_pLeft?=?m_pRight;????????m_pRight?=?pTmp;????}????void?UpdateDistance()????{????????m_iDistance?=?GetRightDistance()+1;????}????int?GetLeftDistance()????{????????return?m_pLeft!=0?m_pLeft-m_iDistance:-1;????}????int?GetRightDistance()????{????????return?m_pRight!=0?m_pRight-m_iDistance:-1;????}????int?m_iData;????int?m_iDistance;????TreeNode*?m_pLeft;????TreeNode*?m_pRight;};//?Stack//////////////////////////////////////////////////////////////////////////class?Stack{public:????Stack(int?iAmount?=?10);????~Stack();????????//return?1?means?succeeded,?0?means?failed.????int?Pop(TreeNode*??val);????int?Push(TreeNode*?val);????int?Top(TreeNode*??val);????????//iterator
您可能关注的文档
最近下载
- 2025至2030年中国工程勘察设计行业市场深度分析及投资前景展望报告.docx
- 静电式油烟净化器安装技术设计.docx VIP
- (品管工具QC七大手法)科建管理顾问有限公司七大手法.pdf VIP
- 中医护理学体质调护.pptx VIP
- GBT 42062风险管理考试及解析.docx VIP
- 物质的分类及转化 同步练习题 高一上学期化学人教版(2019)必修第一册+.docx VIP
- 法律咨询意见书 (2).pdf VIP
- 梅山三小校服“双送检”制度.docx VIP
- 2025变压器声纹振动在线监测装置及监测方法.docx VIP
- 纯电动物流车技术方案及产品技术协议--整车控制器技术协议.docx VIP
文档评论(0)