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

首頁 > 編程 > C > 正文

哈夫曼算法構造代碼

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

1.定義

  哈夫曼編碼主要用于數據壓縮。

  哈夫曼編碼是一種可變長編碼。該編碼將出現頻率高的字符,使用短編碼;將出現頻率低的字符,使用長編碼。

  變長編碼的主要問題是,必須實現非前綴編碼,即在一個字符集中,任何一個字符的編碼都不是另一個字符編碼的前綴。如:0、10就是非前綴編碼,而0、01不是非前綴編碼。

2.哈夫曼樹的構造

  按照字符出現的頻率,總是選擇當前具有較小頻率的兩個節點,組合為一個新的節點,循環此過程知道只剩下一個節點為止。

  對于5個字符A、B、C、D、E,頻率分別用1、5、7、9、6表示,則構造樹的過程如下:

上面過程對應的哈夫曼樹為:

假設規定左邊為0,右邊為1,則變長編碼為:

  A 1:010

  B 5:011

  C 7:10

  D 9:11

  E 6: 00

3.哈夫曼構造代碼

復制代碼 代碼如下:

#include <iostream>
#include <string.h>
using namespace std;
struct Node{
    char c;
    int value;
    int par;
    char tag;    //tag='0',表示左邊;tag='1',表示右邊
    bool isUsed;    //判斷這個點是否已經用過
    Node(){
        par=-1;
        isUsed=false;
    }
};

int input(Node*,int);   //輸入節點信息
int buildedTree(Node*,int); //建哈夫曼樹
int getMin(Node*,int);  //尋找未使用的,具有最小頻率值的節點
int outCoding(Node*,int);   //輸出哈夫曼編碼

int main ()
{
    int n;
    cin>>n;
    Node *nodes=new Node[2*n-1];
    input(nodes,n);
    buildedTree(nodes,n);
    outCoding(nodes,n);
    delete(nodes);
    return 0;
}

int input(Node* nodes,int n){
    for(int i=0;i<n;i++){
        cin>>(nodes+i)->c;
        cin>>(nodes+i)->value;
    }
    return 0;
}

int buildedTree(Node* nodes,int n){
    int last=2*n-1;
    int t1,t2;
    for(int i=n;i<last;i++){
        t1=getMin(nodes,i);
        t2=getMin(nodes,i);
        (nodes+t1)->par=i; (nodes+t1)->tag='0';
        (nodes+t2)->par=i; (nodes+t2)->tag='1';
        (nodes+i)->value=(nodes+t1)->value+(nodes+t2)->value;
    }
    return 0;
}

int getMin(Node* nodes,int n){
    int minValue=10000000;
    int pos=0;
    for(int i=0;i<n;i++)
    {
        if((nodes+i)->isUsed == false && (nodes+i)->value<minValue){
            minValue=(nodes+i)->value;
            pos=i;
        }
    }
    (nodes+pos)->isUsed=true;
    return pos;
}

int outCoding(Node* nodes,int n){
    char a[100];
    int pos,k,j;
    char tmp;
    for(int i=0;i<n;i++){
        k=0;
        pos=i;
        memset(a,'/0',sizeof(a));
        while((nodes+pos)->par!=-1){
            a[k++]=(nodes+pos)->tag;
            pos=(nodes+pos)->par;
        }
        strrev(a);    //翻轉字符串
        cout<<(nodes+i)->c<<" "<<(nodes+i)->value<<":"<<a<<endl;
    }
    return 0;
}

執行示例:

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

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国内精品400部情侣激情| www.久久色.com| 亚洲男人的天堂在线播放| 九九九热精品免费视频观看网站| 国产精品网红直播| 国产精品一区二区三区成人| 色婷婷综合久久久久| 成人国产精品色哟哟| 亚洲午夜精品视频| 日韩精品高清视频| 福利视频第一区| 中文字幕亚洲综合久久| 欧美日韩在线第一页| 成人在线视频福利| 国产精品夜间视频香蕉| 91精品国产91久久久久久久久| 91探花福利精品国产自产在线| 日韩风俗一区 二区| 日韩美女福利视频| 日韩在线视频中文字幕| 亚洲成人动漫在线播放| 久久免费成人精品视频| 日韩av电影手机在线观看| 欧美在线日韩在线| 一区二区三区视频免费在线观看| 国产99久久精品一区二区 夜夜躁日日躁| 97视频在线观看免费高清完整版在线观看| 最近中文字幕2019免费| 亚洲欧洲在线播放| 日韩中文字幕欧美| 日韩久久精品电影| 97福利一区二区| 亚洲人免费视频| 国产欧美va欧美va香蕉在线| 国产一区私人高清影院| 色噜噜狠狠狠综合曰曰曰88av| 色yeye香蕉凹凸一区二区av| 91精品国产免费久久久久久| 日韩精品高清视频| 日韩在线观看电影| 久久国产色av| 自拍视频国产精品| 日韩在线视频一区| 91夜夜未满十八勿入爽爽影院| 欧美成人午夜剧场免费观看| 国产一区二区视频在线观看| 一个人看的www欧美| 色综合视频一区中文字幕| 亚洲激情自拍图| 亚洲精品久久久久久久久久久久久| 琪琪亚洲精品午夜在线| 中文日韩在线视频| 欧美激情综合亚洲一二区| 日韩精品有码在线观看| 国产日韩欧美自拍| 亚洲一区www| 亚洲国产又黄又爽女人高潮的| 亚洲第一精品自拍| 国产噜噜噜噜噜久久久久久久久| 精品夜色国产国偷在线| 亚洲日本欧美中文幕| 92福利视频午夜1000合集在线观看| 亚洲性视频网站| 亚洲一区二区久久久久久久| 亚洲色图偷窥自拍| 欧美中文在线字幕| 国产精品久久久久久久9999| 久久精品欧美视频| 欧美国产日韩中文字幕在线| 国产综合在线视频| 久久精品国产欧美激情| 色综合老司机第九色激情| 欧美亚洲国产视频小说| 国产在线播放不卡| 2020久久国产精品| 久久久国产在线视频| 91经典在线视频| 亚洲人成自拍网站| 91av中文字幕| 91tv亚洲精品香蕉国产一区7ujn| 97人人模人人爽人人喊中文字| 亚洲国产成人久久| 成人亚洲综合色就1024| 久久综合88中文色鬼| 91久久在线播放| 9.1国产丝袜在线观看| 北条麻妃一区二区在线观看| 精品久久久久久久久久久| 欧美资源在线观看| 97视频色精品| 国产精品视频一区国模私拍| 欧美大尺度激情区在线播放| 国产一区二区三区在线视频| 国产精品久久久久av免费| 亚洲欧美制服第一页| 欧美另类极品videosbestfree| 91精品国产乱码久久久久久久久| 国产午夜精品理论片a级探花| 日日噜噜噜夜夜爽亚洲精品| 日韩毛片中文字幕| 成人免费淫片aa视频免费| 精品视频一区在线视频| 亚洲黄色有码视频| 日韩专区在线观看| 国产精品久久97| 91嫩草在线视频| 欧美亚洲日本黄色| www.欧美三级电影.com| 91精品国产精品| 成人免费xxxxx在线观看| 欧美精品第一页在线播放| 欧洲日韩成人av| 亚洲欧美资源在线| 亚洲最大av网站| 欧美成人精品影院| 久久久久久成人精品| 亚洲一级黄色片| 国产精品露脸av在线| 欧美一级视频一区二区| 久久亚洲影音av资源网| 国产一级揄自揄精品视频| 69av在线播放| 在线播放国产一区二区三区| 欧美在线一区二区三区四| 亚洲欧美日韩直播| 亚洲色图偷窥自拍| 欧美中文字幕在线视频| 韩国欧美亚洲国产| 日日噜噜噜夜夜爽亚洲精品| 精品成人av一区| 亚洲精品小视频在线观看| 国内精品国产三级国产在线专| 久久影视电视剧免费网站清宫辞电视| 777国产偷窥盗摄精品视频| 欧美激情亚洲视频| 欧美丝袜一区二区| 精品二区三区线观看| 欧美高清videos高潮hd| 日韩av在线免播放器| 亚洲国产婷婷香蕉久久久久久| 亚洲综合日韩在线| 国产精品久久久久高潮| 国内精久久久久久久久久人| 日韩亚洲国产中文字幕| 亚洲码在线观看| 午夜精品久久久99热福利| 久久男人的天堂| 久久久999精品| 欧美www在线| 国产成人精品视频在线观看| 国产精品视频区1| 精品成人在线视频| 日韩中文有码在线视频| 亚洲香蕉成人av网站在线观看| 国产欧美日韩高清| 久久久久久免费精品| 日日噜噜噜夜夜爽亚洲精品| 国产精品久久久久秋霞鲁丝| 性欧美亚洲xxxx乳在线观看| 78色国产精品| 亚洲国产成人精品久久久国产成人一区| 欧美性精品220| 欧洲成人午夜免费大片| 影音先锋日韩有码|