注册 登录
编程论坛 数据结构与算法

关于赫夫曼中非叶子结点的初始化问题有点不理解,求大神指点

zggdsgs 发布于 2015-05-07 19:39, 2198 次点击
for(;i<=m;++i,++p)
    {
      p->weight=0;
      p->parent=0;
      p->lchild=0;
      p->rchild=0;
    }
为什么代码中i=m呢,非叶子结点不是只有n-1么。
1 回复
#2
zheng20152015-05-31 10:28
这是因为叶子结点有n个,非叶子结点有n-1个,总的结点个数是(m=2*n-1)个。
所以我们总的需要开辟(m+1)*N的空间大小来存储该二叉树,每个结点需要 N 这样大的存储空间,(N是最开始你定义的那个结点的大小)
    for(i=1; i<=n; ++i) {
        p->c=L[i-1].c;
        p->count=L[i-1].count;
        p->parent=0;
        p->lchild=0;
        p->rchild=0;
            p->Hcode;
    }
前面已经将n个结点的值存入线性表(顺序存储)中
    for(; i<=m; ++i) {
        p->count=0;
        p->lchild=0;
        p->parent=0;
        p->rchild=0;
    }
故后面要将n-1个非叶子结点初始化,非叶子结点是从第n+1位处存入线性表中的,
1