亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

哈夫曼的c語言實現代碼

2020-01-26 15:57:24
字體:
來源:轉載
供稿:網友

我們設置一個結構數組 HuffNode 保存哈夫曼樹中各結點的信息。根據二叉樹的性質可知,具有n個葉子結點的哈夫曼樹共有 2n-1 個結點,所以數組 HuffNode 的大小設置為 2n-1 。HuffNode 結構中有 weight, lchild, rchild 和 parent 域。其中,weight 域保存結點的權值, lchild 和 rchild 分別保存該結點的左、右孩子的結點在數組 HuffNode 中的序號,從而建立起結點之間的關系。為了判定一個結點是否已加入到要建立的哈夫曼樹中,可通過 parent 域的值來確定。初始時 parent 的值為 -1。當結點加入到樹中去時,該結點 parent 的值為其父結點在數組 HuffNode 中的序號,而不會是 -1 了。

求葉結點的編碼:
該過程實質上就是在已建立的哈夫曼樹中,從葉結點開始,沿結點的雙親鏈域回退到根結點,每回退一步,就走過了哈夫曼樹的一個分支,從而得到一位哈夫曼碼值。由于一個字符的哈夫曼編碼是從根結點到相應葉結點所經過的路徑上各分支所組成的 0、1 序列,因此先得到的分支代碼為所求編碼的低位,后得到的分支代碼為所求編碼的高位碼。我們可以設置一個結構數組 HuffCode 用來存放各字符的哈夫曼編碼信息,數組元素的結構中有兩個域:bit 和 start。其中,域 bit 為一維數組,用來保存字符的哈夫曼編碼, start 表示該編碼在數組 bit 中的開始位置。所以,對于第 i 個字符,它的哈夫曼編碼存放在 HuffCode[i].bit 中的從 HuffCode[i].start 到 n 的 bit 位中。

復制代碼 代碼如下:

/*-------------------------------------------------------------------------
 * Name:   哈夫曼編碼源代碼。
 * 在 Win-TC 下測試通過
 * 實現過程:著先通過 HuffmanTree() 函數構造哈夫曼樹,然后在主函數 main()中
 *           自底向上開始(也就是從數組序號為零的結點開始)向上層層判斷,若在
 *           父結點左側,則置碼為 0,若在右側,則置碼為 1。最后輸出生成的編碼。
 *------------------------------------------------------------------------*/
#include <stdio.h>

#define MAXBIT      100
#define MAXVALUE  10000
#define MAXLEAF     30
#define MAXNODE    MAXLEAF*2 -1

typedef struct
{
    int bit[MAXBIT];
    int start;
} HCodeType;        /* 編碼結構體 */
typedef struct
{
    int weight;
    int parent;
    int lchild;
    int rchild;
} HNodeType;        /* 結點結構體 */

/* 構造一顆哈夫曼樹 */
void HuffmanTree (HNodeType HuffNode[MAXNODE],  int n)
{
    /* i、j: 循環變量,m1、m2:構造哈夫曼樹不同過程中兩個最小權值結點的權值,
        x1、x2:構造哈夫曼樹不同過程中兩個最小權值結點在數組中的序號。*/
    int i, j, m1, m2, x1, x2;
    /* 初始化存放哈夫曼樹數組 HuffNode[] 中的結點 */
    for (i=0; i<2*n-1; i++)
    {
        HuffNode[i].weight = 0;
        HuffNode[i].parent =-1;
        HuffNode[i].lchild =-1;
        HuffNode[i].lchild =-1;
    } /* end for */

    /* 輸入 n 個葉子結點的權值 */
    for (i=0; i<n; i++)
    {
        printf ("Please input weight of leaf node %d: /n", i);
        scanf ("%d", &HuffNode[i].weight);
    } /* end for */

    /* 循環構造 Huffman 樹 */
    for (i=0; i<n-1; i++)
    {
        m1=m2=MAXVALUE;     /* m1、m2中存放兩個無父結點且結點權值最小的兩個結點 */
        x1=x2=0;
        /* 找出所有結點中權值最小、無父結點的兩個結點,并合并之為一顆二叉樹 */
        for (j=0; j<n+i; j++)
        {
            if (HuffNode[j].weight < m1 && HuffNode[j].parent==-1)
            {
                m2=m1;
                x2=x1;
                m1=HuffNode[j].weight;
                x1=j;
            }
            else if (HuffNode[j].weight < m2 && HuffNode[j].parent==-1)
            {
                m2=HuffNode[j].weight;
                x2=j;
            }
        } /* end for */
            /* 設置找到的兩個子結點 x1、x2 的父結點信息 */
        HuffNode[x1].parent  = n+i;
        HuffNode[x2].parent  = n+i;
        HuffNode[n+i].weight = HuffNode[x1].weight + HuffNode[x2].weight;
        HuffNode[n+i].lchild = x1;
        HuffNode[n+i].rchild = x2;

        printf ("x1.weight and x2.weight in round %d: %d, %d/n", i+1, HuffNode[x1].weight, HuffNode[x2].weight);  /* 用于測試 */
        printf ("/n");
    } /* end for */
} /* end HuffmanTree */

int main(void)
{
    HNodeType HuffNode[MAXNODE];            /* 定義一個結點結構體數組 */
    HCodeType HuffCode[MAXLEAF],  cd;       /* 定義一個編碼結構體數組, 同時定義一個臨時變量來存放求解編碼時的信息 */
    int i, j, c, p, n;
    printf ("Please input n:/n");
    scanf ("%d", &n);
    HuffmanTree (HuffNode, n);

    for (i=0; i < n; i++)
    {
        cd.start = n-1;
        c = i;
        p = HuffNode[c].parent;
        while (p != -1)   /* 父結點存在 */
        {
            if (HuffNode[p].lchild == c)
                cd.bit[cd.start] = 0;
            else
                cd.bit[cd.start] = 1;
            cd.start--;        /* 求編碼的低一位 */
            c=p;                   
            p=HuffNode[c].parent;    /* 設置下一循環條件 */
        } /* end while */

        /* 保存求出的每個葉結點的哈夫曼編碼和編碼的起始位 */
        for (j=cd.start+1; j<n; j++)
        { HuffCode[i].bit[j] = cd.bit[j];}
        HuffCode[i].start = cd.start;
    } /* end for */

    /* 輸出已保存好的所有存在編碼的哈夫曼編碼 */
    for (i=0; i<n; i++)
    {
        printf ("%d 's Huffman code is: ", i);
        for (j=HuffCode[i].start+1; j < n; j++)
        {
            printf ("%d", HuffCode[i].bit[j]);
        }
        printf ("/n");
    }
    getch();
    return 0;
}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品亚发布| 日韩精品在线看| 欧美激情精品久久久久久蜜臀| 国产精品老女人精品视频| 亚洲国产日韩欧美综合久久| 亚洲精选中文字幕| 91久久久在线| 亚洲精品动漫久久久久| 久久久99久久精品女同性| 国产精品678| 国产自产女人91一区在线观看| 日韩中文av在线| 国产精品久久久久久五月尺| 日韩成人在线视频观看| 亚洲高清福利视频| 亚洲另类激情图| 亚洲精品理论电影| 欧美成人黄色小视频| 欧美激情一级欧美精品| 久久久久成人精品| 全球成人中文在线| 尤物99国产成人精品视频| 亚洲国产精品va在看黑人| 亚洲最大福利视频网站| 国产亚洲欧美一区| 国产欧美一区二区三区四区| 综合国产在线视频| 在线免费看av不卡| 在线播放日韩专区| 国产精品欧美激情在线播放| 97国产在线视频| 久久久国产精彩视频美女艺术照福利| 国产一区二区三区精品久久久| 成人性生交大片免费看小说| 久久免费视频在线观看| 亚洲网站在线观看| 欧美日本国产在线| 久久九九亚洲综合| 欧洲永久精品大片ww免费漫画| 欧美一级免费视频| 日韩有码在线观看| 国产精品ⅴa在线观看h| 人妖精品videosex性欧美| 在线观看久久av| 91伊人影院在线播放| 欧美日韩国产一区二区| 色婷婷久久一区二区| 夜色77av精品影院| 91精品久久久久久久久青青| 午夜精品99久久免费| 7m精品福利视频导航| 91精品视频专区| 日韩精品中文字幕有码专区| 亚洲经典中文字幕| 97在线视频免费看| 日本19禁啪啪免费观看www| 一区二区三区四区精品| 久久久精品国产| 精品日韩美女的视频高清| 国产日韩欧美在线播放| 欧美激情在线一区| 欧美主播福利视频| 国产精品扒开腿做| 亚洲**2019国产| 国产丝袜精品第一页| 中文字幕亚洲国产| 情事1991在线| 亚洲精品不卡在线| 亚洲影院污污.| 国产精品爽爽ⅴa在线观看| 国产91露脸中文字幕在线| 亚洲精品美女久久久久| 精品日韩美女的视频高清| 欧美成人四级hd版| 成人性生交大片免费看视频直播| 欧美黑人极品猛少妇色xxxxx| 欧美性猛交xxxx乱大交| 清纯唯美日韩制服另类| 成人国产精品日本在线| 中文字幕免费精品一区高清| 98精品在线视频| 亚洲国产一区二区三区四区| 欧美视频13p| 日韩av中文字幕在线播放| 国产女人精品视频| 亚洲黄色www网站| 日韩av在线一区| 国产精品一区二区三区毛片淫片| 精品一区二区亚洲| 亚洲伦理中文字幕| 福利一区福利二区微拍刺激| 亚洲情综合五月天| 日韩av网站在线| 91人人爽人人爽人人精88v| 精品国模在线视频| www.精品av.com| 欧美香蕉大胸在线视频观看| 久久亚洲国产成人| 欧美日本精品在线| 久久成人综合视频| 中文字幕免费国产精品| 中文字幕日韩电影| 久久的精品视频| 日韩精品极品在线观看| 欧美伊久线香蕉线新在线| 精品欧美一区二区三区| 欧美在线激情视频| 国产精品一二三在线| 成人激情春色网| 亚洲国产精品久久91精品| 国产亚洲一级高清| 日韩电影免费观看在线| 欧美性xxxxx| 2019亚洲日韩新视频| 国产精品精品视频一区二区三区| 国产999精品久久久影片官网| 91久久国产精品91久久性色| 成人激情免费在线| 97在线视频观看| 亚洲а∨天堂久久精品喷水| 亚洲第五色综合网| 亚洲国产91色在线| 久久久久久久久久婷婷| 日韩电影中文 亚洲精品乱码| 国产美女精品免费电影| 欧美性猛交xxxx久久久| 亚洲精品国产成人| 亚洲精品日韩欧美| 亚洲福利视频专区| 欧美日韩性生活视频| 伊人伊人伊人久久| 成人免费xxxxx在线观看| 国产免费一区二区三区在线观看| 国产成人午夜视频网址| 亚洲国产欧美久久| 日韩精品一区二区视频| 精品精品国产国产自在线| 国产精品自产拍高潮在线观看| 中文字幕欧美日韩在线| 日韩网站免费观看高清| 国产精品日韩在线| 91香蕉电影院| 国产欧美日韩精品丝袜高跟鞋| 57pao成人永久免费视频| 亚洲女人天堂av| 亚洲欧美一区二区三区四区| 91天堂在线观看| 91国产视频在线播放| 国产日韩精品电影| 亚洲女在线观看| 欧美午夜性色大片在线观看| 精品人伦一区二区三区蜜桃网站| 理论片在线不卡免费观看| 欧美黑人xxxⅹ高潮交| 欧美日韩精品国产| 中文字幕亚洲一区二区三区| 欧美裸体xxxx极品少妇软件| 欧美成人精品三级在线观看| 国产精品久久久久av| 国产精品日韩精品| 精品国产一区二区三区在线观看| 成人免费在线视频网站| 成人av.网址在线网站| 68精品久久久久久欧美|