Chinaunix首页 | 论坛 | 博客
  • 博客访问: 209433
  • 博文数量: 35
  • 博客积分: 2691
  • 博客等级: 少校
  • 技术积分: 527
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-11 09:42
文章分类

全部博文(35)

文章存档

2012年(5)

2010年(6)

2009年(2)

2008年(22)

我的朋友

分类: C/C++

2008-07-02 12:56:08

//摘自网络
#include
#include
#define MAXSIZE 50
struct code{
        int c;
        int w;
        char code[MAXSIZE];
};
struct node{
        int w;
        int l,r,p;
};
//寻找最小和次小节点
void select_ht_node(node *ht, int n, int &min1, int &min2)
{
        int i;
        min1 = min2  = 0;
        for(i=1; i                if(ht[i].p == -1) {
                        if(ht[min1].w >= ht[i].w) {
                                min2 = min1;
                                min1 = i;
                        } else if(ht[min2].w > ht[i].w) {
                                min2 = i;
                        }
                }
        }
}
//创建huffman树
void creat_huff_tree(node *ht, int length, code *hc)
{
        int i,min1,min2;
        ht[0].w = 65536;
        for(i=1; i<=length; ++i) {
                ht[i].w = hc[i].w;
                ht[i].l = ht[i].r = ht[i].p = -1;
        }
        for(; i<2*length; ++i) {
                ht[i].l = ht[i].r = ht[i].p = -1;
        }
        for(i=length+1; i<2*length; ++i) {
                select_ht_node(ht, i, min1, min2);
                ht[min1].p = ht[min2].p = i;
                ht[i].l = min1;
                ht[i].r = min2;
                ht[i].w = ht[min1].w + ht[min2].w;
        }
}
创建huffman编码
void creat_huff_code(node *ht, int n, code *hc)
{
        for(int i=1; i<=n; ++i) {
                node th = ht[i];
                int tc = i;
                int top = -1;
                int flag[MAXSIZE];
                while(th.p != -1) {
                        top++;
                        if(ht[th.p].l == tc) { flag[top] = 'L'; tc = th.p; }
                        if(ht[th.p].r == tc) { flag[top] = 'R'; tc = th.p; }
                        th = ht[th.p];
                }
                int j = 0;
                while(top != -1) {
                        if(flag[top] == 'L') hc[i].code[j++] = '0';
                        if(flag[top] == 'R') hc[i].code[j++] = '1';
                        top--;
                }
                hc[i].code[j] = '\0';
        }
}
int main()
{
        code huff_code[MAXSIZE];
        node huff_tree[MAXSIZE];
//一般权值是通过计算得出的,这里简化了
        huff_code[1].c = 'A';
        huff_code[1].w = 4;
        huff_code[2].c = 'B';
        huff_code[2].w = 5;
        huff_code[3].c = 'C';
        huff_code[3].w = 6;
        huff_code[4].c = 'D';
        huff_code[4].w = 7;
        huff_code[5].c = 'E';
        huff_code[5].w = 10;
        huff_code[6].c = 'F';
        huff_code[6].w = 12;
        huff_code[7].c = 'G';
        huff_code[7].w = 18;
        creat_huff_tree(huff_tree, 7, huff_code);
        creat_huff_code(huff_tree, 7, huff_code);
        for(int i=1; i<=7; ++i) {
                printf("%c %s\n", huff_code[i].c, huff_code[i].code);
        }
        return 0;
}
阅读(1455) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~