亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? huffman.cpp

?? huffman 編碼程序
?? CPP
字號(hào):
#include<iostream.h> 
#include<iomanip.h> 
#include<stdio.h> 


#define NUM 256 //字母數(shù) 
#define TNUM 511 // 總結(jié)點(diǎn)數(shù)為num+(num-1)
#define CLONG 24 //編碼最大長度 


class Node 
{ 
public: 
   int data;     // byte will be converted to int
   long weight; 
   int parent; 
   int lchild; 
   int rchild; 
}; 

void main() 
{ 
long weight[NUM];//256個(gè)字符出現(xiàn)頻率 
int nzc=0;   //the count of symbol with no zero weight
long maxweight;  // 最大字節(jié)數(shù),根的權(quán)
int maxclength=0,minclength=100;   //碼表中最長的碼
int i,j,smallest,small;
long smallestw,smallw; 
int hcode[NUM][CLONG]; //用于存儲(chǔ)編碼 
int son,father; 
char codetable[256][5];  //碼表 0 長度 1 2 3 為碼 4 為代表的symbol
FILE *source,*destination;
Node nodes[TNUM]; //用對(duì)象數(shù)組存儲(chǔ)哈夫曼樹 

for(i=0;i<NUM;i++){
 nodes[i].data=257;
 nodes[i].weight=0;
 nodes[i].lchild=-1;
 nodes[i].rchild=-1;
 nodes[i].parent=-1;
}

// read the source file and count the weight
for(i=0;i<NUM;i++){
  weight[i]=0;
}
/////////////////////////////////////////////////////////////////////////////

if((source=fopen("compress.txt","w"))==NULL)
{
	printf("source file can not be opened!\n");
    return;
}
for(i=0;i<256;i++){fputc((char)i,source);}



maxweight=ftell(source);
fclose(source);
////////////////////////////////////////////////////////////////////////////////
if((source=fopen("compress.txt","r"))==NULL)
{
	printf("source file can not be opened!\n");
    return;
}
while(!feof(source)){
	weight[(int)(fgetc(source))]++;
}
maxweight=ftell(source);
fclose(source);
//  
nzc=0;
for(i=0;i<NUM;i++) 
{ 
  if(weight[i]!=0)
  {
  nodes[nzc].data=i; 
  nodes[nzc].weight=weight[i]; 
  nzc++;
  }
}            
///now nodes[i] contain only valid value;

for(i=nzc;i<2*nzc-1;i++) 
{ 
nodes[i].data=257;   //其實(shí)不是什么真正的字符
nodes[i].weight=-1; 
nodes[i].parent=-1; 
nodes[i].lchild=-1; 
nodes[i].rchild=-1; 
} 

//建立哈夫曼樹 
for(i=nzc;i<2*nzc-1;i++) 
{ 
smallest=small=-1;    //權(quán)數(shù)最小的兩個(gè)節(jié)點(diǎn)
smallestw=smallw=maxweight; //代表有最小的權(quán)數(shù)的節(jié)點(diǎn)的權(quán)  
for(j=0;j<i;j++) 
{ 
 if(nodes[j].parent==-1) 
 { 
  if(nodes[j].weight<smallestw) 
  {  
   smallw=smallestw; 
   smallestw=nodes[j].weight; 
   small=smallest; 
   smallest=j; 
  } 
  else if(nodes[j].weight>smallestw&&nodes[j].weight<smallw) 
  { 
   smallw=nodes[j].weight; 
   small=j; 
  } 
 } 
}//for語句得到 parent=-1(即尚沒有父結(jié)點(diǎn))且weight最小的兩個(gè)結(jié)點(diǎn) 
nodes[small].parent=i; 
nodes[smallest].parent=i; 
nodes[i].lchild=small; 
nodes[i].rchild=smallest; 
nodes[i].weight=nodes[smallest].weight+nodes[small].weight; 
} 
//到此就完成了樹
//初始化huffman code 
for(i=0;i<nzc;i++) 
{ 
for(j=0;j<CLONG;j++) 
{ 
hcode[i][j]=3;   // any digital will be ok except of '1'and'0' 
} 
} 

//編碼 開始
for(i=0;i<nzc;i++) 
{ 
  j=CLONG-1;   ///從高位向下存
  for(son=i,father=nodes[i].parent;father!=-1;)   // 一定要注意判斷條件。
  { 
   if(nodes[father].lchild==son) 
   { 
    hcode[i][j]=1; 
   } 
   else 
   { 
    hcode[i][j]=0; 
   } 
   j--; 
   son=father,father=nodes[son].parent;
  } 

} 
// 編碼成功 下面創(chuàng)建碼表
int length;
int m,n;
for(i=0;i<nzc;i++){
	length=0;
	for(j=0;j<CLONG;j++)
	{
		if (hcode[i][j]!=3) length++;
	}
    m=7;n=1;
    codetable[i][1]=(char)0;
    codetable[i][2]=(char)0;
    codetable[i][3]=(char)0;
	for(j=CLONG-length;j<CLONG;j++){
		if(hcode[i][j]==1){
        codetable[i][n]=(char)( codetable[i][n]|(char)(1<<m));
		}
		m--;
		if(m==-1){
		n++;
		m=7;
		}
	}
   
	if (length>maxclength) 
	{maxclength=length;}
	if(length<minclength)
	{minclength=length;}
    codetable[i][0]=(char)length;    // 碼表每個(gè)下標(biāo)代表symbol,每個(gè)item第一個(gè)字節(jié)為長度
    codetable[i][4]=(char)nodes[i].data;
}
if((destination=fopen("codetable.txt","w"))==NULL)
{
	printf("source file can not be opened!\n");
    return;
}

for(i=0;i<nzc;i++){
fputc(codetable[i][0],destination);
fputc(codetable[i][1],destination);
fputc(codetable[i][2],destination);
fputc(codetable[i][3],destination);
fputc(codetable[i][4],destination);
}


fclose(destination);
// 特別說明:nodes里面從0到nzc-1都是有效的。
//輸出 nodes 
/*
cout<<"HuffmanTree:"<<endl; 
cout<<setw(4)<<"NO."<<setw(6)<<"data"<<setw(8)<<"weight"<<setw(6) 
<<"parnt"<<setw(6)<<"lchd"<<setw(6)<<"rchd"<<endl; 
for(i=0;i<TNUM;i++) 
{ 
cout<<setw(4)<<i<<setw(6)<<nodes[i].data<<setw(8)<<nodes[i].weight<<setw(6) 
<<nodes[i].parent<<setw(6)<<nodes[i].lchild<<setw(6)<<nodes[i].rchild<<endl; 
} 
*/
//輸出編碼 
cout<<"maxlength"<<maxclength<<"minlength"<<minclength<<endl;
cout<<"from table \n";
i=1;
cout<<"NO."<<i<<":L"<<(int)codetable[i][0]<<":char"<<(int)codetable[i][1]<<(int)codetable[i][2]<<(int)codetable[i][3]<<" "<<(int)codetable[i][4];

/*

  
if((destination=fopen("char.txt","w"))==NULL)
{
	printf("source file can not be opened!\n");
    return;
}

fputc(codetable[0][1],destination);
fputc(codetable[0][2],destination);
fputc(codetable[0][3],destination);

fclose(destination);
	
*/


cout<<"共有"<<nzc<<"個(gè)不是0的";
cout<<endl<<"Result:"<<endl; 
cout<<setw(6)<<"symbol"<<setw(10)<<"frequency"<<setw(16)<<"huffmancode\n"; 
for(i=0;i<nzc;i++) 
{ 
cout<<setw(6)<<nodes[i].data<<setw(10)<<nodes[i].weight; cout<<"    "; 
for(j=0;j<CLONG;j++) 
{ 
  if(hcode[i][j]!=3) 
  { 
   cout<<hcode[i][j]; 
  } 
} 
cout<<endl; 
} 
cout<<"\nDone"<<endl; 

cout<<"共有"<<nzc<<"個(gè)不是0的";


for(i=0;i<nzc;i++) 
{
cout<<nodes[i].data<<"   ";

}
cout<<maxweight;


cout<<"done!";
getchar();
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜久久久久久久久久一区二区| 视频在线观看国产精品| 久久久久久黄色| 欧美xxxxx牲另类人与| 精品日产卡一卡二卡麻豆| 精品乱码亚洲一区二区不卡| 26uuu色噜噜精品一区| 久久久精品一品道一区| 欧美韩国一区二区| 中文字幕一区三区| 午夜久久久久久| 国产在线播精品第三| 粉嫩绯色av一区二区在线观看| 国产成人一区在线| 91福利资源站| 国产日韩av一区二区| 一区二区三区不卡视频在线观看 | 国产精品99久久久久久似苏梦涵| 一二三四区精品视频| 久久久国产精品午夜一区ai换脸| 国产精品高潮久久久久无| 《视频一区视频二区| 视频一区免费在线观看| 国产白丝网站精品污在线入口| 99久久伊人久久99| 精品乱码亚洲一区二区不卡| 国产亚洲成av人在线观看导航| 亚洲三级免费观看| 国产真实乱对白精彩久久| 色老综合老女人久久久| 精品国产a毛片| 婷婷丁香久久五月婷婷| av在线不卡免费看| 久久婷婷成人综合色| 亚洲小少妇裸体bbw| 成人激情黄色小说| 久久精品亚洲乱码伦伦中文| 丝瓜av网站精品一区二区| av动漫一区二区| 精品久久久久av影院| 麻豆国产精品视频| 91精品国产综合久久精品| 亚洲美女少妇撒尿| 91在线高清观看| 国产精品久久久久永久免费观看| 精品一区二区三区影院在线午夜 | 国产精品少妇自拍| 国产一区二区三区免费在线观看| 91麻豆精品国产91久久久更新时间 | 蜜桃视频第一区免费观看| 91久久香蕉国产日韩欧美9色| 国产日韩精品一区| 国产成人激情av| 国产日韩欧美不卡在线| 国产成人精品aa毛片| 国产精品久久久久一区二区三区| 岛国一区二区三区| 亚洲欧美日韩综合aⅴ视频| 色综合天天天天做夜夜夜夜做| 亚洲欧洲精品一区二区精品久久久| aaa国产一区| 亚洲国产另类av| 精品久久一区二区| 成人性生交大片| 午夜久久久久久| 国产日韩三级在线| 欧美日韩国产综合久久 | 成人av片在线观看| 亚洲第一狼人社区| 欧美一级一区二区| 国产99久久久精品| 亚洲毛片av在线| 日韩午夜三级在线| 99麻豆久久久国产精品免费优播| 亚洲欧美福利一区二区| 在线播放视频一区| 成人国产精品免费观看| 亚洲一区二区三区在线播放| 日韩精品一区二区三区在线观看| 国产精品亚洲一区二区三区妖精 | 欧美一区永久视频免费观看| 国内精品国产成人国产三级粉色 | 91丨九色丨国产丨porny| 亚洲.国产.中文慕字在线| 久久综合久久久久88| 欧美三级欧美一级| 成人综合婷婷国产精品久久蜜臀| 视频在线在亚洲| 亚洲国产日韩精品| 亚洲视频资源在线| 国产精品嫩草久久久久| 精品日韩一区二区| 欧美成人激情免费网| 欧美日韩另类一区| 色婷婷av一区二区三区之一色屋| 七七婷婷婷婷精品国产| 日韩专区欧美专区| 亚洲精品国产精华液| 亚洲午夜久久久久久久久电影院 | 夜夜嗨av一区二区三区四季av| 欧美日韩视频在线第一区 | 国产一区福利在线| 久久 天天综合| 国产一区二区三区国产| 免费精品99久久国产综合精品| 亚洲美女免费在线| 一区二区高清免费观看影视大全| 中文字幕亚洲成人| 一区二区三区中文字幕精品精品| 中文字幕av资源一区| 亚洲视频精选在线| 亚洲图片欧美色图| 久久精品国产在热久久| 韩国理伦片一区二区三区在线播放 | 国产激情精品久久久第一区二区 | 国产一区二区免费看| 开心九九激情九九欧美日韩精美视频电影 | 亚洲成人第一页| 久久国产精品99久久久久久老狼 | 亚洲一区二区视频在线观看| 亚洲国产成人tv| 精品一区精品二区高清| 粉嫩av一区二区三区在线播放| 本田岬高潮一区二区三区| 91福利精品第一导航| 欧美精品自拍偷拍动漫精品| 精品999久久久| 亚洲精品欧美激情| 美女脱光内衣内裤视频久久网站| 国产剧情一区二区三区| 欧美性色欧美a在线播放| 欧美成人精品福利| 亚洲欧洲一区二区三区| 麻豆成人在线观看| 色天使色偷偷av一区二区| 26uuu亚洲综合色| 午夜欧美一区二区三区在线播放| 激情综合网av| 欧美精选一区二区| 亚洲另类在线一区| 成人高清av在线| 久久综合九色综合欧美就去吻| 洋洋成人永久网站入口| 欧美丰满美乳xxx高潮www| 国产精品毛片无遮挡高清| 久久丁香综合五月国产三级网站| 在线看日韩精品电影| 亚洲欧洲精品一区二区精品久久久 | 精品在线播放免费| 欧美日韩国产综合一区二区 | 久久精品久久精品| 欧美一卡二卡三卡四卡| 首页国产欧美久久| 欧美精品九九99久久| 亚洲国产成人av| 欧美在线免费观看视频| 国产精品二三区| 91猫先生在线| 亚洲自拍偷拍九九九| 日本道色综合久久| 亚洲综合色噜噜狠狠| 在线观看免费一区| 日日摸夜夜添夜夜添亚洲女人| 欧美人与禽zozo性伦| 一区二区成人在线| 欧美剧情电影在线观看完整版免费励志电影 | 在线亚洲高清视频| 亚洲成人综合在线| 欧美乱熟臀69xxxxxx| 蜜桃精品视频在线| 久久久久国产精品麻豆ai换脸| 国产麻豆日韩欧美久久| 国产精品情趣视频| 色94色欧美sute亚洲线路一久 | 日韩免费一区二区三区在线播放| 麻豆精品久久精品色综合| 国产精品视频你懂的| 欧美制服丝袜第一页| 国内一区二区视频| 亚洲欧美aⅴ...| 欧美一区欧美二区| 99久久99久久免费精品蜜臀| 亚洲国产欧美在线人成| 2021中文字幕一区亚洲| 日本久久精品电影| 久久精品久久精品| 一区二区三区在线视频免费观看 | 亚洲精品在线一区二区| 日本网站在线观看一区二区三区| 国产精品99精品久久免费| 亚洲综合色自拍一区| 国产亚洲综合av| 欧美巨大另类极品videosbest| 国产黄色精品视频| 日韩av在线播放中文字幕| 国产精品久久一卡二卡| 精品国产百合女同互慰| 欧美日韩色一区| av在线播放一区二区三区| 国产精品亚洲第一|