搜索
编程论坛
→
开发语言
→
『 数据结构与算法 』
→ 关于赫夫曼中非叶子结点的初始化问题有点不理解,求大神指点
标题:
关于赫夫曼中非叶子结点的初始化问题有点不理解,求大神指点
只看楼主
zggdsgs
等 级:
新手上路
帖 子:34
专家分:0
注 册:2015-4-6
结帖率:
100%
楼主
问题点数:0 回复次数:1
关于赫夫曼中非叶子结点的初始化问题有点不理解,求大神指点
for(;i<=m;++i,++p)
{
p->weight=0;
p->parent=0;
p->lchild=0;
p->rchild=0;
}
为什么代码中i=m呢,非叶子结点不是只有n-1么。
搜索更多相关主题的帖子:
parent
叶子
2015-05-07 19:39
zheng2015
等 级:
新手上路
帖 子:7
专家分:0
注 册:2015-5-31
第
2
楼
得分:0
这是因为叶子结点有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位处存入线性表中的,
2015-05-31 10:28
2
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-444978-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 1.681283 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved