064.哈夫曼编码

举报
C语言与CPP编程 发表于 2022/04/30 22:26:46 2022/04/30
【摘要】 #include <stdio.h>#define MAX 1000#define MAXSYMBS 30#define MAXNODE 59 typedef struct{ int weight; int flag; int parent; int lchild; int rchild;}huffnode; t...

  
  1. #include <stdio.h>
  2. #define MAX 1000
  3. #define MAXSYMBS 30
  4. #define MAXNODE 59
  5. typedef struct
  6. {
  7. int weight;
  8. int flag;
  9. int parent;
  10. int lchild;
  11. int rchild;
  12. }huffnode;
  13. typedef struct
  14. {
  15. int bits[MAXSYMBS];
  16. int start;
  17. }huffcode;
  18. main()
  19. {
  20. huffnode huff_node[MAXNODE];
  21. huffcode huff_code[MAXSYMBS],cd;
  22. int i,j,m1,m2,x1,x2,n,c,p;
  23. /* char symbs[MAXSYMBS],symb; */
  24. /*数组huff_node初始化*/
  25. clrscr();
  26. printf("please input the leaf num of tree:\n");
  27. scanf("%d",&n);
  28. for(i=0;i<2*n-1;i++)
  29. {
  30. huff_node[i].weight=0;
  31. huff_node[i].parent=0;
  32. huff_node[i].flag=0;
  33. huff_node[i].lchild=-1;
  34. huff_node[i].rchild=-1;
  35. }
  36. printf("please input the weight of every leaf\n");
  37. for(i=0;i<n;i++)
  38. scanf("%d",&huff_node[i].weight);
  39. /*构造哈夫曼树*/
  40. for(i=0;i<n-1;i++)
  41. {
  42. m1=m2=MAX;
  43. x1=x2=0;
  44. for(j=0;j<n+i;j++)
  45. {
  46. if (huff_node[j].weight<m1&&huff_node[j].flag==0)
  47. {
  48. m2=m1;
  49. x2=x1;
  50. m1=huff_node[j].weight;
  51. x1=j;
  52. }
  53. else if (huff_node[j].weight<m2&&huff_node[j].flag==0)
  54. {
  55. m2=huff_node[j].weight;
  56. x2=j;
  57. }
  58. }
  59. huff_node[x1].parent=n+i; /*将找出的两棵子树合并为一棵子树*/
  60. huff_node[x2].parent=n+i;
  61. huff_node[x1].flag=1;
  62. huff_node[x2].flag=1;
  63. huff_node[n+i].weight=huff_node[x1].weight+huff_node[x2].weight;
  64. huff_node[n+i].lchild=x1;
  65. huff_node[n+i].rchild=x2;
  66. }
  67. /*求字符的哈夫曼编码*/
  68. for(i=0;i<n;i++)
  69. {
  70. cd.start=n;
  71. c=i;
  72. p=huff_node[c].parent;
  73. while(p!=0)
  74. {
  75. if(huff_node[p].lchild==c)
  76. cd.bits[cd.start]=0;
  77. else
  78. cd.bits[cd.start]=1;
  79. cd.start=cd.start-1;
  80. c=p;
  81. p=huff_node[p].parent;
  82. }
  83. cd.start++;
  84. for(j=cd.start;j<=n;j++)
  85. huff_code[i].bits[j]=cd.bits[j];
  86. huff_code[i].start=cd.start;
  87. }
  88. /*输出字符的哈夫曼编码*/
  89. puts("The Hafman code are:");
  90. for(i=0;i<n;i++)
  91. {
  92. for(j=huff_code[i].start;j<=n;j++)
  93. printf("%10d",huff_code[i].bits[j]);
  94. printf("\n");
  95. }
  96. puts("Press any key to quit...");
  97. getch();
  98. }

文章来源: blog.csdn.net,作者:程序员编程指南,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/weixin_41055260/article/details/124495723

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。