Aaron-NZH 2019-06-26 12:49 采纳率: 33.3%
浏览 512

想请教一下全局变量在递归中是怎么样的

以下是一个函数完整的代码
利用static int code[10]来保存哈夫曼编码
但是static 的东西不是只有一个吗,在向左右子树递归的时候不会冲突吗
想了解以下code这个数组在这个函数的递归中是怎么被改变的

void HuffManCoding(BTreeNode *FBT, int len)
{
    // 根据FBT指针所指向的哈夫曼树输出每个叶子的编码,len初值为0
    static int code[10];    // 数组的长度要至少等于哈夫曼树的深度减1
    if (FBT != NULL) {
        // 访问到叶子结点时输出其保存在数组code中的0和1序列编码
        if (FBT->left == NULL && FBT->right == NULL) {
            cout << "结点权值为" << FBT->weight << "的编码:";
            for (int i = 0; i < len; i++)
                cout << code[i] << " ";
            cout << endl;
        }

        // 访问到非叶子节点时分别向左、右子树递归调用,并分别把分支上
        // 的0、1编码保存到数组code,向下深入一层时len+1
        else {
            code[len] = 0; HuffManCoding(FBT->left, len + 1);
            code[len] = 1; HuffManCoding(FBT->right, len + 1);
        }
    }
}
  • 写回答

2条回答 默认 最新

  • threenewbee 2019-06-26 12:51
    关注

    这个可以参考下相关的书都有递归相关的介绍的

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器