锘??xml version="1.0" encoding="utf-8" standalone="yes"?>精品免费久久久久久久,精品人妻久久久久久888,久久久久久免费一区二区三区 http://www.shnenglu.com/Marcky/archive/2009/09/28/97474.htmlMarcky Marcky Mon, 28 Sep 2009 09:49:00 GMT http://www.shnenglu.com/Marcky/archive/2009/09/28/97474.html http://www.shnenglu.com/Marcky/comments/97474.html http://www.shnenglu.com/Marcky/archive/2009/09/28/97474.html#Feedback 0 http://www.shnenglu.com/Marcky/comments/commentRss/97474.html http://www.shnenglu.com/Marcky/services/trackbacks/97474.html typedef struct _HTNode { unsigned int weight; /* 鏉冨?nbsp; */ unsigned int parent; /* 鐖惰妭鐐圭儲(chǔ)寮?nbsp; */ unsigned int lchild; /* 宸﹀瀛愮儲(chǔ)寮?nbsp; */ unsigned int rchild; /* 鍙沖瀛愮儲(chǔ)寮?nbsp; */ } HTNode, * HuffmanTree; /* 鍔ㄦ佸垎閰嶆暟緇勫瓨鍌ㄥ搱澶浖鏍?nbsp; */ typedef char ** HuffmanCode; /* 鍔ㄦ佸垎閰嶆暟緇勫瓨鍌ㄥ搱澶浖緙栫爜琛?nbsp; */ /* 浠巋t鐨?锝瀗鐨勮妭鐐逛腑鎵懼嚭鏉冨兼渶灝忕殑涓や釜鑺傜偣錛屽垎鍒瓨?shù)簬s1, s2涓?nbsp; */ void Select(HuffmanTree ht, int n, int * s1, int * s2) { int i; * s1 = 0 ; * s2 = 0 ; /* 璁劇疆s1, s2鍒板紑濮嬩袱涓猵arent絳変簬0鐨勮妭鐐逛綅緗?/span>*/ for (i = 1 ; i <= n; ++ i) { if ( * s1 != 0 && * s2 != 0 ) break ; if (ht[i].parent == 0 ) * s1 == 0 ? * s1 = i : * s2 = i; } /* 鎵懼嚭ht涓璸arent絳変簬0錛屼笖鏉冨兼渶灝忕殑涓や釜鑺傜偣浣嶇疆錛屽垎鍒瓨?shù)簬s1, s2涓?/span>*/ for ( ; i <= n; ++ i) { if (ht[i].parent != 0 ) continue ; if ( (ht[ * s1].weight > ht[ * s2].weight) && (ht[ * s1].weight > ht[i].weight)) * s1 = i; else if ( (ht[ * s2].weight > ht[ * s1].weight) && (ht[ * s2].weight > ht[i].weight)) * s2 = i; } } /* 閫氳繃w瀛樺偍鐨刵涓潈鍊鹼紝鏉ュ垱寤轟竴棰楀搱澶浖鏍? ht_ptr鎸囧悜榪欓鍝堝か鏇兼爲(wèi) */ void CreateHuffmanTree(HuffmanTree * ht_ptr, int * w, int n) { int m; int i; int s1, s2; HuffmanTree p; if (n <= 1 ) return ; m = 2 * n - 1 ; /* n涓瓧絎︼紝闇瑕?n-1涓┖闂存潵瀛樺偍鏁撮huffman tree */ * ht_ptr = (HuffmanTree)malloc( (m + 1 ) * sizeof (HTNode)); /* 0鍙峰崟鍏冧笉鐢?nbsp; */ for (p = * ht_ptr + 1 , i = 1 ; i <= n; ++ i, ++ p, ++ w) { /* 鍒濆鍖栨暟緇勪腑鍓峮涓崟鍏冨瓨鍌ㄧ殑瀛楃 */ p-> weight = * w; p -> parent = 0 ; p -> lchild = 0 ; p -> rchild = 0 ; } for ( ; i <= m; ++ i, ++ p) { /* 鍒濆鍖栨暟緇勪腑鍓╀綑鐨勫崟鍏?nbsp; */ p-> weight = 0 ; p -> parent = 0 ; p -> lchild = 0 ; p -> rchild = 0 ; } for (i = n + 1 ; i <= m; ++ i) { Select( * ht_ptr, i - 1 , & s1, & s2); /* 璁劇疆s1, s2鐨勭埗浜蹭負(fù)i */ (* ht_ptr + s1) -> parent = i; ( * ht_ptr + s2) -> parent = i; /* 璁劇疆i鐨勫乏瀛╁瓙涓簊1, 鍙沖瀛愪負(fù)s2 */ (* ht_ptr + i) -> lchild = s1; ( * ht_ptr + i) -> rchild = s2; /* 璁劇疆i鐨勬潈鍊間負(fù)s1, s2涔嬪拰 */ (* ht_ptr + i) -> weight = ( * ht_ptr + s1) -> weight + ( * ht_ptr + s2) -> weight; } } /* 瀵筯t_ptr瀛樺偍鐨勫搱澶浖鏍?wèi)鐨刵涓彾瀛愯妭鐐硅繘琛屽搱澶浖緙栫爜 */ void HuffmanCoding(HuffmanTree * ht_ptr, HuffmanCode * hc_ptr, int n) { int i; int start; char * cd = NULL; * hc_ptr = (HuffmanCode)malloc( (n + 1 ) * sizeof ( char * )); cd = ( char * )malloc(n * sizeof ( char )); cd[n - 1 ] = ' \0 ' ; for (i = 1 ; i <= n; ++ i) { start = n - 1 ; int current, father; for (current = i, father = ( * ht_ptr + i) -> parent; /* 浠庡彾瀛愯妭鐐瑰紑濮嬶紝騫跺彇寰楃埗鑺傜偣father */ father != 0 ; /* 鐖惰妭鐐逛負(fù)0鏃跺強(qiáng)鍒拌揪浜?jiǎn)鏍硅妭鐐?nbsp; */ current = father, father = ( * ht_ptr + father) -> parent) { /* 閫愭笎鍚戞牴鑺傜偣闈犳嫝 */ if ( ( * ht_ptr + father) -> lchild == current) /* 褰撳墠鑺傜偣涓哄乏瀛╁瓙 */ cd[-- start] = ' 0 ' ; else cd[-- start] = ' 1 ' ; } * ( * hc_ptr + i) = ( char * )malloc( (n - start) * sizeof ( char )); strcpy( * ( * hc_ptr + i), & cd[start]); } free(cd); }
]]> 浜屽弶鏍?wèi)鐨勫垱寰忓強(qiáng)閬嶅巻锛堥掑綊浠g爜錛?/title> http://www.shnenglu.com/Marcky/archive/2009/09/24/97173.htmlMarcky Marcky Thu, 24 Sep 2009 14:33:00 GMT http://www.shnenglu.com/Marcky/archive/2009/09/24/97173.html http://www.shnenglu.com/Marcky/comments/97173.html http://www.shnenglu.com/Marcky/archive/2009/09/24/97173.html#Feedback 0 http://www.shnenglu.com/Marcky/comments/commentRss/97173.html http://www.shnenglu.com/Marcky/services/trackbacks/97173.html typedef enum _STATUS {ERROR, OK} STATUS; typedef struct _BiTNode { char data; struct _BiTNode * lchild; struct _BiTNode * rchild; } BiTNode, * BiTree; /* 鍒涘緩浜屽弶鏍?/span>*/ STATUS CreateBiTree(BiTree * T) { /* 鎸夊厛搴忔搴忚緭鍏ヤ簩鍙夋爲(wèi)鑺傜偣鐨勫鹼紝絀烘牸琛ㄧず絀烘爲(wèi)銆?/span>*/ char ch; scanf( " %c " , & ch); if (ch == ' ' ) { * T = NULL; } else { if ( ! ( * T = (BiTNode * )malloc( sizeof (BiTNode)))) exit( - 1 ); ( * T) -> data = ch; // 鐢熸垚鏍硅妭鐐?/span> CreateBiTree( & (( * T) -> lchild)); // 鏋勯犲乏瀛愭爲(wèi) CreateBiTree( & (( * T) -> rchild)); // 鏋勯犲彸瀛愭爲(wèi) } return OK; } /* 涓簭閬嶅巻浜屽弶鏍?/span>*/ STATUS InOrderTraverse(BiTree * T) { if ( * T) { if (InOrderTraverse( & (( * T) -> lchild))) printf( " %c " , ( * T) -> data); if (InOrderTraverse( & (( * T) -> rchild))) return OK; return ERROR; } else { return OK; } }
]]>
国产精品久久久亚洲 |
热re99久久精品国产99热 |
亚洲人AV永久一区二区三区久久 |
九九久久精品国产 |
亚洲欧美成人久久综合中文网 |
久久久亚洲裙底偷窥综合 |
久久er99热精品一区二区 |
中文精品久久久久国产网址 |
欧美精品丝袜久久久中文字幕 |
国产亚洲精品久久久久秋霞
|
国产精品欧美久久久天天影视 |
国产精品成人99久久久久 |
久久伊人五月丁香狠狠色 |
久久久久四虎国产精品 |
亚洲国产精品久久久天堂 |
精品国产91久久久久久久a |
久久综合香蕉国产蜜臀AV |
久久综合成人网 |
久久播电影网 |
国产欧美久久一区二区 |
色88久久久久高潮综合影院 |
久久精品国产清自在天天线 |
国产麻豆精品久久一二三 |
久久精品国产免费观看 |
色老头网站久久网 |
久久996热精品xxxx |
伊人久久综合热线大杳蕉下载 |
久久久久久亚洲AV无码专区 |
亚洲午夜久久久影院 |
2021国产精品久久精品 |
久久这里有精品视频 |
日韩十八禁一区二区久久 |
91久久精品无码一区二区毛片 |
99久久精品国产麻豆 |
国产精品久久久久国产A级 |
国产高潮国产高潮久久久 |
久久人人爽人人爽人人片AV不 |
亚洲精品午夜国产VA久久成人 |
yy6080久久 |
日韩精品无码久久久久久 |
欧美一区二区三区久久综合 |