为了账号安全,请及时绑定邮箱和手机立即绑定

基于哈夫曼树的数据压缩算法

基于哈夫曼树的数据压缩算法

晴书 2017-11-07 15:16:51
#include <iostream>#include <stdio.h>#include <string>using namespace std;#define MAXN 1000typedef struct { int weight; int parent, lchild, rchild;}HTNode, *HuffmanTree;typedef char **HuffmanCode;void Count(char str[], int count[]){ for (int i = 1; i <= 26; i++) {  count[i] = 0; } for (int i = 0; i <strlen(str); i++) {  count[str[i] - 'a' + 1]++; }}void Select(HuffmanTree &HT, int n, int &a, int &b){ unsigned int m1, m2; m1 = m2 = 32767; for (int i = 1; i <= n; i++) {  if (HT[i].parent == 0 && HT[i].weight < m1)  {   m2 = m1;   b = a;   m1 = HT[i].weight;   a = i;  }  else   if (HT[i].parent == 0 && HT[i].weight < m2)   {    m2 = HT[i].weight;    b = i;   } }}void CreatHuffmanTree(HuffmanTree &HT, int n, int count[]){ if (n <= 1) return; int m; m = 2 * n - 1; HT = new HTNode[m + 1]; for (int i = 1; i <= m; i++) {  HT[i].parent = 0;  HT[i].lchild = 0;  HT[i].rchild = 0; } int j; for (int i = 1,j=1; i <= n,j<=26; j++) {  if (count[j] > 0)  {   HT[i].weight = count[j];   i++;  }  } int s1, s2; for (int i = n + 1; i <= m; i++) {  Select(HT, i - 1, s1, s2);  HT[s1].parent = i;  HT[s2].parent = i;  HT[i].lchild = s1;  HT[i].rchild = s2;  HT[i].weight = HT[s1].weight + HT[s2].weight; }}void CreatHuffmanCode(HuffmanTree HT, HuffmanCode &HC, int n){ char *cd; HC = new char*[n + 1]; cd = new char[n]; cd[n - 1] = '\0'; int start = 0; int c, f; for (int i = 1; i <= n; i++) {  start = n - 1;  c = i;  f = HT[i].parent;  while (f != 0)  {   start--;   if (HT[f].lchild == c)   {    cd[start] = '0';   }   else   {    cd[start] = '1';   }    c = f;    f = HT[f].parent;     }  HC[i] = new char[n - start];  strcpy(HC[i], &cd[start]); } delete cd;}int main() { char str[MAXN]; int count[50]; int n; while (cin >> str&&*str != '0') {  n = 0;  Count(str, count);  for (int i = 97; i<123; i++)  {   if (count[i - 96] > 0)   {    n++;    printf("%c:%d ", i, count[i - 96]);   }  }  cout << endl;  HuffmanTree HT;  CreatHuffmanTree(HT, n, count);  for (int i = 1; i <= 2 * n - 1; i++)  {   cout << i << " " << HT[i].weight << " " << HT[i].parent << " " << HT[i].lchild << " " << HT[i].rchild << endl;  }  HuffmanCode HC;  CreatHuffmanCode(HT, HC, n);  int j;  for (int i = 1; i<n; i++)  {   printf("%c:%s ", i, HC[i]);  //输出编码结果  }  cout << endl;  for (int i = 0; i<strlen(str); i++)  {   cout << HC[str[i] - 'a' + 1];  }  cout << endl;  for (int i = 0; i<strlen(str); i++)   cout << str[i];  cout << endl; } return 0;}用aabb这样开头的就可以过 eeeeffg就不行哪个大神帮我看看哪里需要改
查看完整描述

目前暂无任何回答

  • 0 回答
  • 0 关注
  • 2812 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信