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

首頁 > 學院 > 開發設計 > 正文

c語言哈夫曼編碼

2019-11-10 18:38:22
字體:
來源:轉載
供稿:網友
#include<stdio.h>#include<string.h>#include<malloc.h>typedef struct character{char str;int  count;int index; } character; //一棵樹需要左孩子,右孩子,非葉子節點上的數字  typedef struct Tree {    int left;  int right;  int count;  int index;  char str;  char code[256]; }Tree;//統計字符串的各字符的頻率,以及記錄不同字符的個數,排序character *getCharCount(int *count,char *String);//輸出統計后各個字符,頻率 void showChar(Tree *tree,int count);//形成一個二叉樹 void PRoTree(Tree *tree,int count,character *chars);//形成編碼void decode(Tree *tree,int root,int index,char *code);//編碼void afterDecode(Tree *tree,char *String,int count,char *afterString); //編碼后輸出void putcode(char *String); void putcode(char *String){puts(String);}void afterDecode(Tree *tree,char *String,int count,char *afterString){int i,j;for(i=0;String[i];i++){for(j=0;j<count;j++){if(tree[j].str==String[i]){strcat(afterString,tree[j].code);}}}strcpy(String,afterString);}void decode(Tree *tree,int root,int index,char *code) {if(tree[root].left==-1){code[index]=0;strcpy(tree[root].code,code);}else    {code[index]='1';decode(tree,tree[root].left,index+1,code);code[index]='0';decode(tree,tree[root].right,index+1,code);}}void proTree(Tree *tree,int count,character *chars){int i;int j;for(i=0;i<count;i++){tree[i].index=i;tree[i].left=-1;tree[i].right=-1;tree[i].count=chars[i].count;tree[i].str=chars[i].str; }for(i=count,j=i-2;i<2*count-1;i++){tree[i].index=i;tree[i].left=tree[i-1].index;tree[i].right=tree[j].index;tree[i].count=tree[i-1].count+tree[j--].count;tree[i].str=' '; }}void showChar(Tree *tree,int count) {int i;printf("下標  字符   頻率     編碼    左孩子    右孩子/n");for(i=0;i<2*count-1;i++){printf("%2d  %5c  %4d   %7s   %5d    %6d/n",tree[i].index,tree[i].str,tree[i].count,tree[i].code,tree[i].left,tree[i].right);} } character *getCharCount(int *count,char *String){character *p=NULL;character t;int i,j=0;int k=0;int chars[256]={0};for(i=0;String[i];i++)chars[String[i]]++;for(i=0;i<256;i++){if(chars[i]){k++;}}*count=k;p=(character *)(calloc(sizeof(character),k));for(i=0;i<256;i++){if(chars[i]){p[j].str=i;p[j++].count=chars[i];}}for(i=0;i<k;i++)for(j=0;j<k-i-1;j++)if(p[j].count<p[j+1].count){t=p[j];p[j]=p[j+1];p[j+1]=t; }for(i=0;i<k;i++)p[i].index=i;return p; }int main(){char String[256];char afterString[256]={0};character *chars;Tree *tree;int count;char code[256];printf("請輸入一串字符串:/n");gets(String);chars=getCharCount(&count,String);tree=(Tree *)(calloc(sizeof(Tree),2*count-1));proTree(tree,count,chars);decode(tree,2*count-2,0,code);showChar(tree,count);afterDecode(tree,String,count,afterString);putcode(String);free(chars);free(tree); }
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产伦精品免费视频| 国产日韩欧美综合| 黑人狂躁日本妞一区二区三区| 欧美精品激情在线观看| 在线观看久久av| 中文字幕亚洲自拍| 成人国产精品日本在线| 日韩精品久久久久久久玫瑰园| 国产精品av电影| 视频直播国产精品| 亚洲缚视频在线观看| 在线午夜精品自拍| 亚洲精品国产综合区久久久久久久| 日韩精品高清视频| 欧美日韩亚洲国产一区| 97碰碰碰免费色视频| 亚洲精品国精品久久99热一| 成人黄色短视频在线观看| 精品久久久免费| 韩国19禁主播vip福利视频| 青青精品视频播放| 精品久久在线播放| 亚洲国产成人精品电影| 精品国产一区二区三区在线观看| 国产亚洲欧美日韩精品| 亚洲三级免费看| 欧美一二三视频| 国产欧美日韩中文| 国产成人精品视频在线观看| 午夜精品久久久久久久久久久久久| 亚洲精品视频二区| 国产精品丝袜久久久久久不卡| 亚洲最大福利视频网| 欧美激情精品久久久久久黑人| 国产精品99久久久久久久久| 国产精品人人做人人爽| 国产一区二区三区日韩欧美| 最近2019年手机中文字幕| 国产精品久久视频| 欧美日韩另类在线| 亚洲国产成人精品一区二区| 在线观看国产精品91| 欧美精品在线极品| 欧美精品aaa| 97久久久免费福利网址| 欧美精品videosex牲欧美| 91高清视频在线免费观看| 久久国产精品影片| 欧美精品videos| 亚洲精品免费在线视频| 国产一区二区三区在线免费观看| 日韩av免费看| 国模gogo一区二区大胆私拍| 色偷偷偷综合中文字幕;dd| 国产精品十八以下禁看| 伊人久久大香线蕉av一区二区| 日日摸夜夜添一区| 久久深夜福利免费观看| 久久久久久久91| …久久精品99久久香蕉国产| 日韩欧美在线视频日韩欧美在线视频| 精品久久久久久久久久久久久久| 国产在线播放不卡| 国语自产精品视频在线看抢先版图片| 精品久久久香蕉免费精品视频| 不卡av在线网站| 91久久精品国产91性色| 欧美成人午夜激情| 久久香蕉国产线看观看网| 秋霞成人午夜鲁丝一区二区三区| 欧美小视频在线| 精品久久久视频| 国产精品∨欧美精品v日韩精品| 精品国内产的精品视频在线观看| 欧美高清性猛交| 欧美中文字幕在线播放| 久久久久久网站| 亚洲国产小视频在线观看| 青青久久av北条麻妃海外网| 欧美肥臀大乳一区二区免费视频| 欧美日韩国产激情| 亚洲国产成人在线视频| 亚洲欧洲在线播放| 日韩视频亚洲视频| 国产精品久久久久久久久久99| 亚洲一区第一页| 亚洲综合在线做性| 久久亚洲精品一区| 国产久一一精品| 国内精品小视频在线观看| 亚洲成人激情小说| 国产成人激情小视频| 亚洲成人动漫在线播放| 欧美日本中文字幕| 6080yy精品一区二区三区| 97超级碰碰碰久久久| 奇米4444一区二区三区| 亚洲成色999久久网站| 国内精品视频在线| 久久综合久久88| 国产精品96久久久久久| 国产在线播放91| 国产精品日韩电影| 一区二区在线免费视频| 久久精品精品电影网| 亚洲片在线观看| 亚洲视频欧美视频| 大荫蒂欧美视频另类xxxx| 美女啪啪无遮挡免费久久网站| 久久久精品久久久| 日韩美女福利视频| 久久综合久久88| 欧美精品电影在线| 91久久久久久| 亚洲精品久久久久中文字幕欢迎你| 欧美黑人xxxⅹ高潮交| 欧美一区二区大胆人体摄影专业网站| 日韩欧美在线第一页| 国产精品com| 欧美午夜精品久久久久久浪潮| 亚洲男人天堂网站| 久久国产精彩视频| 亚洲美女在线视频| 精品亚洲男同gayvideo网站| 久久久av网站| 日韩精品极品在线观看| 亚洲黄色av网站| 91在线免费看网站| 国产一区二区三区免费视频| 日韩视频在线免费| 亚洲成人久久电影| 精品福利一区二区| 日本在线精品视频| 狠狠躁夜夜躁人人爽超碰91| 色爱精品视频一区| 日韩欧美精品网址| 日韩在线免费观看视频| 久久亚洲精品国产亚洲老地址| 日本中文字幕不卡免费| 欧美成人免费一级人片100| 日韩在线播放av| 国内精品一区二区三区| 精品动漫一区二区三区| 日韩av第一页| 亚洲精品视频在线播放| 亚洲男人av电影| 日本欧美中文字幕| 国产精品久久久久久影视| 久久久久久久电影一区| 亚洲美腿欧美激情另类| 亚洲国产欧美日韩精品| 日本午夜人人精品| 欧美激情啊啊啊| 亚洲国产日韩欧美在线图片| 亚洲国产成人精品电影| 国产精品白嫩美女在线观看| 欧美裸体xxxx极品少妇| 国产成人精品视频在线观看| 久久久黄色av| 日韩男女性生活视频| 91成人天堂久久成人| 成人免费视频网| 国产丝袜一区视频在线观看| 欧美日韩免费看|