ZBLOG

#include #include typedef struct Node { int weight; int parent, left, right; } HuffmanNode; int buildHuffmanTree(HuffmanNode *huffmanNodes, int n) { int m = 2 * n - 1; HuffmanNode *nodes = huffmanNodes; i...

以下是将您提供的代码完全转换为C语言的版本:

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. typedef struct Node {
  5. int weight;
  6. int parent, left, right;
  7. } HuffmanNode;
  8. int buildHuffmanTree(HuffmanNode *huffmanNodes, int n) {
  9. int m = 2 * n - 1;
  10. HuffmanNode *nodes = huffmanNodes;
  11. int i;
  12. for (i = 0; i < m; i++) {
  13. nodes[i].parent = nodes[i].left = nodes[i].right = -1;
  14. }
  15. for (i = n; i < m; i++) {
  16. int min1 = INT_MAX, min2 = INT_MAX;
  17. int x1, x2;
  18. int j;
  19. for (j = 0; j < i; j++) {
  20. if (nodes[j].parent == -1) {
  21. if (nodes[j].weight < min1) {
  22. min2 = min1;
  23. x2 = x1;
  24. min1 = nodes[j].weight;
  25. x1 = j;
  26. }
  27. else if (nodes[j].weight < min2) {
  28. min2 = nodes[j].weight;
  29. x2 = j;
  30. }
  31. }
  32. }
  33. nodes[x1].parent = i;
  34. nodes[x2].parent = i;
  35. nodes[i].left = x1;
  36. nodes[i].right= x2;
  37. nodes[i].weight= min1 + min2;
  38. }
  39. return m - 1;
  40. }
  41. void generateHuffmanCode(HuffmanNode *huffmanNodes, char **codes, int root, int depth, char *code) {
  42. if (root < 0) {
  43. return ;
  44. }
  45. if (huffmanNodes[root].left == -1 && huffmanNodes[root].right == -1) { // 叶子节点
  46. code[depth] = '\0';
  47. codes[root] = (char *)malloc((depth + 1) * sizeof(char));
  48. strcpy(codes[root], code);
  49. } else {
  50. code[depth] = '0';
  51. generateHuffmanCode(huffmanNodes, codes, huffmanNodes[root].left, depth + 1, code);
  52. code[depth] = '1';
  53. generateHuffmanCode(huffmanNodes, codes, huffmanNodes[root].right, depth + 1, code);
  54. }
  55. }
  56. int main() {
  57. int n,i;
  58. scanf("%d", &n);
  59. HuffmanNode *huffmanNodes = (HuffmanNode *)malloc((2 * n - 1) * sizeof(HuffmanNode));
  60. for (i = 0; i < n; i++) {
  61. scanf("%d", &huffmanNodes[i].weight);
  62. }
  63. int root = buildHuffmanTree(huffmanNodes, n);
  64. char **codes = (char **)malloc(n * sizeof(char *));
  65. char *code= (char *)malloc(n * sizeof(char));
  66. generateHuffmanCode(huffmanNodes, codes, root, 0, code);
  67. for (i = 0; i < n; i++) {
  68. printf("%s\n", codes[i]);
  69. free(codes[i]);
  70. }
  71. free(huffmanNodes);
  72. free(codes);
  73. free(code);
  74. return 0;
  75. }

请注意,此代码是按照您提供的原始代码进行转换的,我并未进行任何优化或修改。希望对您有所帮助!


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=9834

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?