baishir 2019-01-02 01:08
浏览 304

哈弗曼编码,从根到叶子,权值从数组为0开始,会出问题,以下代码,知道问题出现在下标为0的权值无法编码

while(p1)
    {
        if(HT[p1].weight==0)    //向左
        {
            HT[p1].weight=1;
            if(HT[p1].lchild!=0)
            {
                p1=HT[p1].lchild;
                printf("p1为%d  \n",p1);
                cd[cdlen]='0';
                cdlen++;
            }
            else if(HT[p1].lchild==0&&HT[p1].rchild==0)  //登记叶子结点的字符编码
            {
                HC[p1]=(char *)malloc(cdlen*sizeof(char));
                cd[cdlen]='\0';
                strcpy(HC[p1],cd);    //复制编码串
                printf("HC的值%s\n",HC[p1]);
            }
        }
        else if(HT[p1].weight==1) //向右
        {
            HT[p1].weight=2;
            if(HT[p1].rchild!=0)
            {
                p1=HT[p1].rchild;
                cd[cdlen]='1';
                cdlen++;
            }
        }
        else                  //HT[p1].weight==2,退回
        {
            HT[p1].weight=0;
            p1=HT[p1].parent;
            --cdlen;          //退到父节点,编码长度减1
        }
    }
  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
    • ¥15 如何在scanpy上做差异基因和通路富集?
    • ¥20 关于#硬件工程#的问题,请各位专家解答!
    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 截图中的mathematics程序转换成matlab
    • ¥15 动力学代码报错,维度不匹配
    • ¥15 Power query添加列问题
    • ¥50 Kubernetes&Fission&Eleasticsearch
    • ¥15 報錯:Person is not mapped,如何解決?