青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

no_rain

huffman 編碼學習

該程序實現的功能是將一段字符串進行統計之后再進行huffman編碼(二進制);
注意的地方:
1,huffman編碼要用到貪心算法,所以用priority_queue可以在常量時間內取出和插入值。
2,靜態建樹:huffman樹的節點表示方法采用了最多的變量,即父親節點,左右子節點(因為程序中確實有這種需要,這里不同與二叉堆,無法通過在靜態樹(鏈表)的位置來確定其父親節點和子節點); 

  1 #include<iostream>
  2 #include<cstring>
  3 #include<queue>
  4 #include<cstdlib>
  5 using namespace std;
  6 const int MAXSIZE = 27;
  7 class huffNode{
  8 public:
  9   int pr;
 10   int lc , rc;
 11   char s;
 12   int pow;
 13   bool operator < (const huffNode& b)const{
 14     return pow > b.pow;
 15   }
 16 };
 17 huffNode huff[MAXSIZE * 2];
 18 string buf;
 19 int count[26];
 20 priority_queue<huffNode> greed;
 21 //for the sake of convenience , assume that the
 22 //standard input is from 'a' to 'z'.
 23 int  input(){
 24   cout << "input the text!"<<endl;
 25   cin >> buf;
 26   for(int i = 0; i < 26 ; i++) count[i] = 0;
 27   memset(huff , 0, sizeof(huff));
 28   for(int i = 0; i < buf.length();i++)count[buf[i]-'a']++;
 29   int len = 0;
 30   for(int i = 0 ,j = 0; i < 26; i++)
 31     if(count[i]){
 32       huff[j].s = i + 'a';
 33       huff[j].pow = count[i];
 34       huff[j].pr = j;
 35       cout << "the" << ' '<<'\''<< char(i+'a') <<'\''
 36        <<' '<<"have arisen for " <<count[i]<<" time(s)"
 37        <<endl;
 38       greed.push(huff[j]);
 39       len = j;
 40       j++;
 41     }
 42   return len;
 43 }
 44 
 45 int createTree(int len){
 46   if(len == 0) {
 47     cout << " Only one kind of alf !"<<endl;
 48     exit(1);
 49   }
 50   huffNode temp1 ,temp2,temp;
 51   while(!greed.empty()){
 52     temp1 = greed.top();
 53     greed.pop();
 54     temp2 = greed.top();
 55     greed.pop();
 56     len ++;
 57     temp.lc = temp1.pr;
 58     temp.rc = temp2.pr;
 59     huff[temp1.pr].pr = huff[temp2.pr].pr = len;
 60     temp.pr = len;
 61     temp.pow = temp1.pow + temp2.pow;
 62     huff[len] = temp;
 63     if(!greed.empty()) greed.push(temp);
 64   }
 65   return len;
 66 }
 67 
 68 void reserve(char * a){
 69   int len = strlen(a);
 70   for(int i = 0 ; i <= len/2 ;i ++)
 71     swap(a[i],a[len-i-1]);
 72 }
 73 struct code{
 74   char s;
 75   char co[50];
 76 };
 77 
 78 void coding(int len1,int len2){
 79   code* mycode = new code[len1+1];
 80   memset(mycode ,0 ,sizeof(mycode));
 81   for(int i = 0; i <= len1 ; i++){
 82     int j = i;
 83     int t = 0;
 84     mycode[i].s = huff[i].s;
 85     while(j < len2){
 86       if(huff[huff[j].pr].lc == j)
 87     mycode[i].co[t++] = '0';
 88       else mycode[i].co[t++] = '1';
 89       j = huff[j].pr ;
 90     }
 91     reserve(mycode[i].co);
 92     cout << "the code of " << mycode[i].s
 93      << " is " << mycode[i].co <<endl;
 94   }
 95   delete[] mycode;
 96 }
 97 
 98 int main(){
 99   int len1 = input();
100   int len2 = createTree(len1);
101   coding(len1,len2); 
102 }
103   
104   
105       
106 

posted on 2011-12-06 14:46 is-programmer 閱讀(427) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


導航

<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

統計

常用鏈接

留言簿

隨筆檔案

文章分類

文章檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产一区二区高清视频| 有码中文亚洲精品| 亚洲综合导航| 在线中文字幕不卡| 国产精品视区| 久久久精彩视频| 久久久久久久999| 亚洲激情视频网| 99热精品在线| 国产欧美一区二区在线观看| 久久久精品国产一区二区三区 | 亚洲欧美影院| 亚洲欧美国产精品专区久久| 好看不卡的中文字幕| 媚黑女一区二区| 欧美人妖另类| 久久精品中文| 欧美久久电影| 欧美中文在线观看国产| 老司机免费视频久久| 亚洲特黄一级片| 欧美呦呦网站| 亚洲精品乱码视频| 亚洲欧美综合网| 亚洲美女精品成人在线视频| 亚洲欧美日韩一区在线观看| 悠悠资源网亚洲青| 在线亚洲欧美专区二区| 在线观看成人网| 99视频超级精品| 在线观看一区二区视频| 亚洲私人影院| 亚洲国产另类久久久精品极度| 一本大道av伊人久久综合| 国产综合色产| 一区二区三区四区五区精品视频| 狠狠爱成人网| 亚洲视频在线观看网站| 亚洲高清在线播放| 校园春色国产精品| 亚洲视频一区| 欧美成人性网| 免费成人黄色av| 国产日韩欧美制服另类| 一本久道久久久| 亚洲国产日日夜夜| 久久婷婷久久| 裸体女人亚洲精品一区| 国产欧美91| 在线午夜精品| 亚洲天堂av在线免费| 欧美超级免费视 在线| 久久视频在线看| 国产日韩欧美在线视频观看| 日韩一区二区免费看| 亚洲精品在线免费观看视频| 久久精品一本| 久热精品在线视频| 红桃视频国产精品| 久久激情综合| 久久久国产午夜精品| 国产日韩欧美精品一区| 亚洲一区二区三区视频| 午夜精品www| 国产日韩欧美在线| 性色av香蕉一区二区| 欧美伊人久久大香线蕉综合69| 欧美午夜免费影院| 亚洲无限av看| 欧美亚洲一区二区在线观看| 国产精品区免费视频| 亚洲性色视频| 久久精品国产一区二区三区| 国产欧美日本在线| 欧美中文在线免费| 蜜臀av国产精品久久久久| 在线观看中文字幕不卡| 卡通动漫国产精品| 亚洲欧洲精品一区| 一区二区三区四区五区视频| 欧美午夜不卡视频| 亚洲欧美一级二级三级| 久久免费国产| 亚洲三级性片| 国产精品麻豆成人av电影艾秋| 亚洲男人av电影| 麻豆精品视频在线观看| 亚洲开发第一视频在线播放| 欧美日韩18| 先锋影音网一区二区| 狂野欧美激情性xxxx欧美| 亚洲精品免费在线| 欧美日韩视频专区在线播放| 午夜国产不卡在线观看视频| 久久亚洲国产成人| av成人动漫| 国产一区二区三区免费不卡| 欧美a级片网| 亚洲性线免费观看视频成熟| 久久婷婷av| 一区二区欧美日韩视频| 国产日韩三区| 欧美精品一区二区在线播放| 午夜宅男久久久| 亚洲欧洲在线一区| 久久激情网站| 夜夜狂射影院欧美极品| 国产亚洲欧美日韩一区二区| 欧美电影免费观看高清| 午夜亚洲性色视频| 亚洲精品一区二区在线观看| 久久久久久精| 亚洲欧美精品| 亚洲精品在线观| 精品二区久久| 国产毛片一区| 欧美视频免费在线观看| 麻豆精品在线观看| 性久久久久久久久久久久| 亚洲精品视频一区二区三区| 久久网站热最新地址| 亚洲欧美日韩国产综合| 日韩小视频在线观看专区| 黄色亚洲在线| 国产日本欧美在线观看| 国产精品va| 欧美另类videos死尸| 免播放器亚洲一区| 欧美在线二区| 午夜宅男久久久| 亚洲一区二区三区精品在线| 日韩小视频在线观看专区| 亚洲国产欧美一区二区三区同亚洲| 久久精品国产欧美亚洲人人爽| 亚洲综合色噜噜狠狠| 一区二区三区精密机械公司| 亚洲国产精品一区二区尤物区| 黑人极品videos精品欧美裸| 国产日韩欧美一区二区三区在线观看| 欧美四级电影网站| 欧美三日本三级少妇三2023| 欧美片网站免费| 欧美日韩国产一区精品一区| 欧美成人综合网站| 欧美国产精品劲爆| 欧美黑人在线观看| 欧美区在线播放| 欧美日韩精品免费在线观看视频| 欧美精品国产一区| 欧美日韩日本网| 欧美小视频在线| 国产麻豆精品视频| 国产真实乱子伦精品视频| 国产在线拍偷自揄拍精品| 国内外成人免费视频| 狠狠色综合色综合网络| 在线观看视频日韩| 亚洲国产欧美一区二区三区久久 | 亚洲欧洲久久| 亚洲精品一品区二品区三品区| 亚洲精品久久久久久久久久久久久 | 欧美在线观看视频| 久久精品水蜜桃av综合天堂| 久久蜜桃资源一区二区老牛 | 久久国产精品久久久久久久久久 | 香港成人在线视频| 一本大道av伊人久久综合| 99国产精品一区| 亚洲精品视频在线观看网站| 亚洲精品一区中文| 亚洲欧美精品在线| 免费观看成人网| 国产精品v欧美精品v日韩| 国产情人综合久久777777| 亚洲成色最大综合在线| 在线视频免费在线观看一区二区| 香蕉久久夜色| 欧美成人官网二区| 一本色道久久综合亚洲精品婷婷| 久久大逼视频| 欧美另类在线播放| 国内精品福利| 中文一区字幕| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲三级免费| 欧美影院一区| 欧美日韩一二区| 伊人婷婷欧美激情| 午夜伦欧美伦电影理论片| 欧美福利一区二区| 午夜精品一区二区三区在线播放| 欧美成人一区二区三区在线观看 | 国产精品xxx在线观看www| 一色屋精品视频在线看| 亚洲夜间福利| 欧美激情一区二区| 久久国产精品99久久久久久老狼 | 蜜桃精品一区二区三区| 国产伦理精品不卡| 亚洲天堂av在线免费|