c语言二叉树 双向链表是二叉树的链式存储结构,这句话不对,为什么?
浏览量:2840
时间:2021-03-12 09:32:33
作者:admin
双向链表是二叉树的链式存储结构,这句话不对,为什么?
事实上,这句话没有问题,因为二进制数不一定满足二进制数,但它在最大程度上是二进制数。只有完全二叉树满足每个非叶节点都是二叉树,双向链表与无向树相同。只要链表的头和尾没有连接,它就是一种特殊的二叉树——链表
链表结构的优点是易于寻址。二进制列表的缺点是结构开销随着数据结构的大小而增加(特别是叶节点有两个空值,即丢失2*sizeof(ElemType*)
线性结构的优点是没有结构开销,缺点是不方便插入和删除?
试用情况的估计取决于问题的大小,即空间复杂度和时间复杂度
两者的相互转换非常简单,只需了解在顺序存储中:
父节点(currentpos)=(currentpos-1)/2当前节点,取下限
左(currentpos)=2*currentpos 1
右(currentpos)=2*currentpos 2
左brother=[currentpos-1
右brother=currentpos 1
转换时,我们只需要将链式存储结构的数据字段的数据复制到顺序存储结构的相应位置即可
6。将ABCDE存储在完全二叉树的顺序存储结构中,给出了二叉树的链式存储结构以及二叉树的前序、中序和后序遍历序列
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。