我应该如何构造这种树

rick1126 2002-06-03 09:37:20
有这样一个树型结构的节目单:
频道->节目->节目项->任务, 请问我该如何构造树???

目前我给树节点提供5个指针, 父指针, 左兄弟指针, 右兄弟指针, 子树的首尾指针2个. 因为插入的时候我的数据是一个包含了前面4个层次的一个数据结构描述的单位就是任务, 这意味着我需要逐层查询需要插入的位置, 这样的设计好不好, 遍历我应该使用什么算法, 按照层次???

因为目前我的程序从网络接收节目单, 存储成为数据结构, 不过如果使用链表虽然简单, 但是要求我输出一个XML文档, 这样需要进行多重循环, 为此我想到树, 这样结构附加一个垃圾回收结构(负责回收删除的节点给以后使用, 因为节目单实时更新, 我不想产生太多因为频繁new和delete造成的内存碎片)
...全文
50 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
rick1126 2002-06-03
  • 打赏
  • 举报
回复
这些编号来自数据库, 为此一般使用UINT限定范围, 所以你的方法我目前已经在使用, 使用双向链表, 这样对于构造XML不好, 基于效率我要求使用fprintf或者类似方法直接输出XML而不是DOM, 这在前一个版本当中被证明效率太低.
chen780831 2002-06-03
  • 打赏
  • 举报
回复
是不是可以这样:
给每个节点加上一个编号:
如频道为前两位:00(以后依次为01、02...)
节目为四位:0000(0001--0099、0100--0199...)
以次类推:节目项就是六位,任务就是八位。
再把节点加入链表,就可以很容易的实现父节点,子节点和兄弟节点的查找。
如任务为00000000,则很容易知道其上父节点为000000

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧