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

首頁 > 編程 > C++ > 正文

基于C++實現的哈夫曼編碼解碼操作示例

2020-05-23 13:30:54
字體:
來源:轉載
供稿:網友

本文實例講述了基于C++實現的哈夫曼編碼解碼操作。分享給大家供大家參考,具體如下:

哈夫曼編碼是一個通過哈夫曼樹進行的一種編碼,一般情況下,以字符:‘0'與‘1'表示。編碼的實現過程很簡單,只要實現哈夫曼樹,通過遍歷哈夫曼樹,這里我們從每一個葉子結點開始向上遍歷,如果該結點為父節點的左孩子,則在字符串后面追加“0”,如果為其右孩子,則在字符串后追加“1”。結束條件為沒有父節點。然后將字符串倒過來存入結點中。

C++實現代碼如下:

#include<iostream>#include<string>using namespace std;struct Node{  double weight;  string ch;  string code;  int lchild, rchild, parent;};void Select(Node huffTree[], int *a, int *b, int n)//找權值最小的兩個a和b{  int i;  double weight = 0; //找最小的數  for (i = 0; i <n; i++)  {    if (huffTree[i].parent != -1)   //判斷節點是否已經選過      continue;    else    {      if (weight == 0)      {        weight = huffTree[i].weight;        *a = i;      }      else      {        if (huffTree[i].weight < weight)        {          weight = huffTree[i].weight;          *a = i;        }      }    }  }  weight = 0; //找第二小的數  for (i = 0; i < n; i++)  {    if (huffTree[i].parent != -1 || (i == *a))//排除已選過的數      continue;    else    {      if (weight == 0)      {        weight = huffTree[i].weight;        *b = i;      }      else      {        if (huffTree[i].weight < weight)        {          weight = huffTree[i].weight;          *b = i;        }      }    }  }  int temp;  if (huffTree[*a].lchild < huffTree[*b].lchild) //小的數放左邊  {    temp = *a;    *a = *b;    *b = temp;  }}void Huff_Tree(Node huffTree[], int w[], string ch[], int n){  for (int i = 0; i < 2 * n - 1; i++) //初始過程  {    huffTree[i].parent = -1;    huffTree[i].lchild = -1;    huffTree[i].rchild = -1;    huffTree[i].code = "";  }  for (int i = 0; i < n; i++)  {    huffTree[i].weight = w[i];    huffTree[i].ch = ch[i];  }  for (int k = n; k < 2 * n - 1; k++)  {    int i1 = 0;    int i2 = 0;    Select(huffTree, &i1, &i2, k); //將i1,i2節點合成節點k    huffTree[i1].parent = k;    huffTree[i2].parent = k;    huffTree[k].weight = huffTree[i1].weight + huffTree[i2].weight;    huffTree[k].lchild = i1;    huffTree[k].rchild = i2;  }}void Huff_Code(Node huffTree[], int n){  int i, j, k;  string s = "";  for (i = 0; i < n; i++)  {    s = "";    j = i;    while (huffTree[j].parent != -1) //從葉子往上找到根節點    {      k = huffTree[j].parent;      if (j == huffTree[k].lchild) //如果是根的左孩子,則記為0      {        s = s + "0";      }      else      {        s = s + "1";      }      j = huffTree[j].parent;    }    cout << "字符 " << huffTree[i].ch << " 的編碼:";    for (int l = s.size() - 1; l >= 0; l--)    {      cout << s[l];      huffTree[i].code += s[l]; //保存編碼    }    cout << endl;  }}string Huff_Decode(Node huffTree[], int n,string s){  cout << "解碼后為:";  string temp = "",str="";//保存解碼后的字符串  for (int i = 0; i < s.size(); i++)  {    temp = temp + s[i];    for (int j = 0; j < n; j++)    {      if (temp == huffTree[j].code)      {        str=str+ huffTree[j].ch;        temp = "";        break;      }      else if (i == s.size()-1&&j==n-1&&temp!="")//全部遍歷后沒有      {        str= "解碼錯誤!";      }    }  }  return str;}int main(){  //編碼過程  const int n=5;  Node huffTree[2 * n];  string str[] = { "A", "B", "C", "D", "E"};  int w[] = { 30, 30, 5, 20, 15 };  Huff_Tree(huffTree, w, str, n);  Huff_Code(huffTree, n);  //解碼過程  string s;  cout << "輸入編碼:";  cin >> s;  cout << Huff_Decode(huffTree, n, s)<< endl;;  system("pause");  return 0;}

運行結果如下:

C++,哈夫曼,編碼,解碼

希望本文所述對大家C++程序設計有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久91| 精品视频在线播放| 黄色91在线观看| 国产精品老女人精品视频| 91视频免费在线| 国内免费精品永久在线视频| 日本乱人伦a精品| 中文字幕av日韩| 欧美人与性动交a欧美精品| 91情侣偷在线精品国产| 色吧影院999| 日韩在线视频网站| 亚洲男人的天堂网站| 欧美黑人视频一区| 91国内在线视频| 一区二区欧美日韩视频| 欧美日产国产成人免费图片| 久久久电影免费观看完整版| 亚洲伊人一本大道中文字幕| 成人h猎奇视频网站| 2018日韩中文字幕| 久久久精品视频成人| 久久伊人免费视频| 亚洲一区二区久久久久久| 精品动漫一区二区| 日韩精品在线播放| 亚洲成人教育av| 国产精品xxxxx| 欧美一区二粉嫩精品国产一线天| 日韩禁在线播放| 中文字幕国产日韩| 综合国产在线视频| 久久伊人91精品综合网站| 亚洲男人天堂2024| 国产精品精品视频| 日本高清不卡的在线| 欧美激情久久久久| 亚洲精品视频在线观看视频| 国产亚洲精品成人av久久ww| 疯狂欧美牲乱大交777| 欧美乱大交xxxxx另类电影| 亚洲第一在线视频| 91精品视频大全| 亚洲专区中文字幕| 中文日韩电影网站| 国产精品永久免费观看| 欧美理论电影网| 久久精品一区中文字幕| 成人国产精品久久久久久亚洲| 亚洲性视频网址| 亚洲综合大片69999| 91在线视频九色| 亚洲精品suv精品一区二区| 亚洲第一精品自拍| 日韩中文字幕在线视频| 久久久久久中文字幕| 欧美性猛交xxxxx水多| 欧美激情久久久久久| 国语自产精品视频在线看| 亚洲成色999久久网站| 亚洲一区二区三区毛片| 欧美第一黄网免费网站| 国产精品aaa| 97婷婷大伊香蕉精品视频| 国产精品一区av| 国产亚洲精品91在线| 久久久99免费视频| 久久亚洲精品成人| 国产主播在线一区| 日韩av在线影视| 亚洲一区中文字幕| 日本a级片电影一区二区| 亚洲大胆人体在线| 精品国内亚洲在观看18黄| 亚洲国产日韩欧美在线图片| 国产精品扒开腿爽爽爽视频| 成人xxxxx| 成人a在线观看| 欧美激情亚洲综合一区| 精品久久久久久电影| 欧美日韩免费在线观看| 最新69国产成人精品视频免费| 久久久久久久久久久人体| 国产精品第七影院| 激情久久av一区av二区av三区| 57pao国产成人免费| 自拍亚洲一区欧美另类| 欧美一区二区影院| 欧美精品一区三区| 日韩欧美一区二区三区久久| 国产日韩专区在线| 日韩av手机在线| 国产欧美在线看| 亚洲福利视频专区| 国产精品久久久久久久久免费| 亚洲乱码av中文一区二区| 欧美国产在线视频| 国产www精品| 亚洲人成网7777777国产| 成人av色在线观看| 国产97在线|亚洲| 色妞色视频一区二区三区四区| 色哟哟亚洲精品一区二区| 国产精品九九久久久久久久| 自拍偷拍免费精品| 亚洲天堂av图片| 欧美精品日韩www.p站| 亚洲精品久久久久中文字幕欢迎你| 国产丝袜一区二区三区免费视频| 国产精品欧美一区二区| 国产精品久久久久高潮| 欧美专区第一页| …久久精品99久久香蕉国产| 中文字幕最新精品| 成人h视频在线观看播放| 午夜欧美大片免费观看| 久久久久国产精品一区| 国产综合色香蕉精品| 国产精品久久久久aaaa九色| 国产一区二区三区在线免费观看| 一色桃子一区二区| 亚洲一区二区久久久久久| 欧美香蕉大胸在线视频观看| 欧美一级淫片aaaaaaa视频| 亚洲精品国产精品国自产观看浪潮| 国产精品视频1区| 国产一区二区丝袜| 国外成人在线视频| 亚洲人成人99网站| 91探花福利精品国产自产在线| 欧美老女人bb| 96sao精品视频在线观看| 国产激情综合五月久久| 亚洲欧美精品伊人久久| 国产精品免费久久久| 亚洲女人天堂成人av在线| 欧美精品第一页在线播放| 91免费的视频在线播放| 日韩麻豆第一页| 久久免费视频观看| 日韩国产中文字幕| 亚洲人成在线观看网站高清| 亚洲欧美国产va在线影院| 国产精品免费视频久久久| 北条麻妃一区二区三区中文字幕| 国产精品精品视频一区二区三区| 亚洲欧美日韩视频一区| 九九热r在线视频精品| 欧美激情亚洲一区| 欧美在线国产精品| 色老头一区二区三区在线观看| 亚洲色图五月天| 一本大道香蕉久在线播放29| 久久99热精品这里久久精品| 日韩中文字幕在线视频播放| 日韩专区中文字幕| 亚洲性线免费观看视频成熟| 欧美丝袜一区二区三区| 在线中文字幕日韩| 亚洲美女视频网站| 欧美成人精品一区| 国产精品对白刺激| 日本精品久久中文字幕佐佐木| 国产亚洲一区二区在线|