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

no_rain

huffman 編碼學(xué)習(xí)

該程序?qū)崿F(xiàn)的功能是將一段字符串進(jìn)行統(tǒng)計(jì)之后再進(jìn)行huffman編碼(二進(jìn)制);
注意的地方:
1,huffman編碼要用到貪心算法,所以用priority_queue可以在常量時(shí)間內(nèi)取出和插入值。
2,靜態(tài)建樹:huffman樹的節(jié)點(diǎn)表示方法采用了最多的變量,即父親節(jié)點(diǎn),左右子節(jié)點(diǎn)(因?yàn)槌绦蛑写_實(shí)有這種需要,這里不同與二叉堆,無法通過在靜態(tài)樹(鏈表)的位置來確定其父親節(jié)點(diǎn)和子節(jié)點(diǎn)); 

  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) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


導(dǎo)航

<2012年2月>
2930311234
567891011
12131415161718
19202122232425
26272829123
45678910

統(tǒng)計(jì)

常用鏈接

留言簿

隨筆檔案

文章分類

文章檔案

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            新67194成人永久网站| 99精品欧美| 久久久久国产精品麻豆ai换脸| 国产乱码精品一区二区三区忘忧草| 一本久久精品一区二区| 亚洲免费av片| 国产精品一区二区视频| 久久精品99久久香蕉国产色戒| 香蕉乱码成人久久天堂爱免费 | 你懂的亚洲视频| 老司机凹凸av亚洲导航| 亚洲美女在线看| 亚洲无吗在线| 国内精品99| 亚洲第一页在线| 欧美婷婷久久| 久久久亚洲一区| 欧美承认网站| 中文在线不卡视频| 欧美一区二区三区四区视频| 亚洲国产日韩在线| 一本久久综合亚洲鲁鲁| 国产在线欧美日韩| 欧美成人午夜激情在线| 国产精品国产亚洲精品看不卡15| 久久精品一区二区| 欧美韩国日本一区| 欧美在线一二三区| 欧美精品一区二区三区视频 | 国产在线拍偷自揄拍精品| 欧美韩日一区二区| 国产精品国产三级国产aⅴ入口 | 久久久噜噜噜久久狠狠50岁| 免费成人av资源网| 欧美一区精品| 欧美日韩理论| 欧美mv日韩mv国产网站| 欧美午夜免费影院| 亚洲二区三区四区| 国产视频在线观看一区| 日韩一级免费| 亚洲精品一区二区三区不| 性欧美暴力猛交另类hd| 亚洲视频999| 亚洲国产成人午夜在线一区 | 激情成人av在线| 午夜在线电影亚洲一区| 亚洲第一精品福利| 亚洲先锋成人| 日韩视频不卡| 久久亚洲一区二区三区四区| 欧美一级艳片视频免费观看| 欧美欧美天天天天操| 欧美成人精精品一区二区频| 国产日韩视频一区二区三区| 亚洲天堂成人| 亚洲一区二区三区免费观看 | 久久99在线观看| 亚洲欧美日韩国产中文| 亚洲一区二区毛片| 欧美日韩国产精品自在自线| 国产精品老牛| 亚洲成色999久久网站| 国产精品一卡二| a4yy欧美一区二区三区| 99亚洲精品| 欧美精品18videos性欧美| 女仆av观看一区| 在线成人av网站| 久久久福利视频| 欧美成人蜜桃| 亚洲高清资源综合久久精品| 久久婷婷亚洲| 亚洲成人中文| 日韩亚洲欧美精品| 欧美视频精品在线| 亚洲午夜精品一区二区| 西瓜成人精品人成网站| 国产亚洲一区在线| 在线成人性视频| 久久伊伊香蕉| 亚洲欧美电影院| 国产模特精品视频久久久久| 亚洲一区精品视频| 久久免费99精品久久久久久| 狠狠色丁香婷婷综合久久片| 久久亚洲精品视频| 亚洲精品综合久久中文字幕| 在线亚洲一区二区| 国产九九视频一区二区三区| 欧美一区二区久久久| 另类酷文…触手系列精品集v1小说| 亚洲国产欧美一区| 欧美日韩免费一区| 欧美伊人久久久久久久久影院| 免费观看日韩| 亚洲一区二区三区高清不卡| 国产日韩欧美中文在线播放| 久热精品视频在线观看一区| aa国产精品| 久久手机免费观看| 中国日韩欧美久久久久久久久| 国产日本精品| 欧美日韩免费看| 久久久亚洲国产天美传媒修理工| 亚洲国产精品传媒在线观看| 香蕉久久国产| 亚洲美女一区| 精品动漫3d一区二区三区免费 | 久久资源在线| 亚洲午夜极品| 亚洲人成网在线播放| 国产欧美一区二区三区另类精品 | 亚洲综合清纯丝袜自拍| 欧美激情一区二区三区四区| 午夜在线播放视频欧美| 亚洲人成久久| 狠色狠色综合久久| 国产精品都在这里| 欧美成年人视频| 欧美在线视频一区二区三区| 99热精品在线| 亚洲国产第一| 欧美国产日韩精品免费观看| 久久国产一区二区| 在线亚洲欧美专区二区| 亚洲人成网站精品片在线观看| 国产亚洲欧美一级| 国产精品天美传媒入口| 欧美日一区二区在线观看 | 亚洲永久字幕| 99视频一区二区三区| 欧美黄色一区| 欧美~级网站不卡| 蜜臀久久久99精品久久久久久| 久久经典综合| 久久久久久久综合色一本| 午夜精品久久久久久久99水蜜桃 | 日韩亚洲欧美在线观看| 亚洲电影有码| 亚洲黄色av| 亚洲日本欧美| 亚洲精品免费在线| 亚洲伦理中文字幕| 日韩一级免费| 国产精品99久久久久久久vr| 一区二区欧美精品| 一本久久a久久精品亚洲| 日韩一区二区电影网| 亚洲精品激情| 一二三区精品| 亚洲影院在线| 欧美亚洲一区二区三区| 久久国产88| 蜜桃av一区二区三区| 欧美不卡一区| 亚洲麻豆av| 亚洲小视频在线观看| 午夜天堂精品久久久久| 久久不射中文字幕| 久久一区二区三区国产精品 | 国产精品v欧美精品v日本精品动漫 | 久久gogo国模裸体人体| 久久电影一区| 欧美电影免费观看高清完整版| 欧美日韩精品一区视频| 国产精品久久久久国产精品日日| 国产精品美女www爽爽爽| 国产最新精品精品你懂的| 亚洲国产精品va在线看黑人 | 亚洲高清不卡av| 99日韩精品| 久久不见久久见免费视频1| 美女精品视频一区| 亚洲精品视频免费| 亚洲欧美一区在线| 欧美xx视频| 国产日韩精品在线播放| 亚洲国产美国国产综合一区二区 | 国产亚洲精品久久久久婷婷瑜伽| 国语精品中文字幕| 一区二区日本视频| 久久米奇亚洲| 亚洲精品乱码久久久久久黑人| 午夜国产精品影院在线观看| 久久久欧美精品| 国产精品久久7| 亚洲国产一区二区三区青草影视| 国产精品99久久99久久久二8| 久久久夜夜夜| 中文精品视频| 免费成人黄色| 国模套图日韩精品一区二区| 亚洲婷婷免费| 亚洲高清一区二区三区| 欧美一区二区三区四区夜夜大片| 欧美日韩免费视频| 亚洲黄一区二区| 另类av一区二区| 亚洲一区三区电影在线观看|