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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? huffman.cpp

?? 超級經(jīng)典的
?? CPP
字號:
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
typedef struct{
	double weight;
	int parent,lchild,rchild;
}HTnode,*HTree;
void InitData();
void select(HTree HT, int len, int* index1, int* index2);
int create(HTree* HT, double* weight, int num);
void huffmanCode(HTree HT, char** HC,int num);
void huffmanCoding();//編碼過程
void dhuffmanCoding();//譯碼過程
void show();
double data[1000][4]={0};
int length=0,l=0,n=0;
char* HC[1000];  //定義指向編碼串的指針數(shù)組
int main()
{
	int i=0;
	double qdata[1000];
	memset(HC,0,1000);
	memset(qdata,0,1000);
	InitData();
	for(i=0;i<n;i++)
		qdata[i]=data[i][3];	
	HTree HT;
	//創(chuàng)建Huffman樹
	create(&HT,qdata,n);
	//編碼
	huffmanCode(HT,HC,n);
	//打印編碼串
	for(i = 0; i < n;++i)
		printf("%f-%f-%f: %s\n",data[i][1],data[i][2],data[i][3],HC[i]);
	show();
	printf("共有:%d條記錄及%d個權值\n",length,n);
	printf("正在編碼中....\n");
	printf("正在將編碼數(shù)據(jù)寫入code.txt文件中....\n");
	huffmanCoding();
	printf("編碼完成......\n");
	printf("正在譯碼中....\n");
	printf("正在將譯碼數(shù)據(jù)寫入data.txt文件中....\n");
	dhuffmanCoding();
	printf("譯碼完成......\n");
	system("pause");
	return 0;
}
void InitData()
{
	int i,flag=0;
	double temp=0;
	FILE* p=fopen("hfm.txt","r");
	while(1)
	{
		fscanf(p,"%lf",&temp);
		for(i=0;i<n;i++)
		{
			if(temp==data[i][1])
			{
				flag=1;
				data[i][2]=data[i][2]+1;
				length++;
				for(i=0;i<n;i++)
					data[i][3]=data[i][2]/length;
				break;
			}
		}
		if(flag==0)
		{
			data[n][1]=temp;
			data[n][2]=data[n][2]+1;
			length++;
			n++;
			for(i=0;i<n;i++)
				data[i][3]=data[i][2]/length;	
		}
		if(feof(p))break;
		flag=0;
	}
	fclose(p);
}
void select(HTree HT, int len, int* index1, int* index2){
	int i;
	//初始化*index1
	for(i = 0; i < len; i++)
		if(HT[i].parent == 0){
			*index1 = i;
			break;
		}
		//求最小值*index1
		for(i = 0; i < len; i++)
			if(HT[i].parent == 0)
				if(HT[i].weight < HT[*index1].weight)
					*index1 = i;
				//初始化*index2
				for(i = 0; i < len; i++)
					if(HT[i].parent == 0 && i!= *index1){
						*index2 = i;
						break;
					}
					//求次小值*index2:
					for(i = 0; i < len; ++i)
						if(i != *index1)
							if(HT[i].parent == 0)
								if(HT[i].weight < HT[*index2].weight)
									*index2 = i;
								
}
//創(chuàng)建Huffman樹:
int create(HTree* HT, double* weight, int num){
	int i, nodeNum;
	int min1,min2;
	double* w = weight;
	HTree p;
	if(num <= 1)
		return 1;
	nodeNum = 2*num - 1;
	//分配所有結點的空間
	(*HT) = (HTree)malloc(sizeof(HTnode)*nodeNum);
	if(!(*HT))
		return -1;
	//對葉子結點初始化
	for(i = 0, p = *HT; i < num; ++i, ++p,++w){
		p->weight = *w;
		p->lchild = p->rchild = p->parent = 0;
	}
	//對剩余的非葉子結點初始化
	for( ; i < nodeNum; ++i,++p)
		p->weight = p->lchild = p->rchild =p->parent = 0;
	//鏈接各個結點形成Huffman樹
	for(i = num; i < nodeNum; ++i){
		select(*HT, i ,&min1,&min2);
		(*HT)[min1].parent = i;
		(*HT)[min2].parent = i;
		(*HT)[i].weight = (*HT)[min1].weight + (*HT)[min2].weight;
		//最小值為其左孩子,次小值為其右孩子,也可以按照反順序,那么得到的編碼有些不同
		(*HT)[i].lchild = min1;
		(*HT)[i].rchild = min2;
	}
	return 1;
}
//編碼函數(shù):在已建立的Huffman樹的基礎之上進行編碼(從字符到對應的01串的過程)
void huffmanCode(HTree HT, char** HC,int num){
	int i,temp,start,par;
	char* workSpace;
	//申請求編碼要用的工作空間,該空間最大為2*num-1-num+1 = num個字節(jié)
	workSpace = (char*)malloc(num*sizeof(char));
	//不需要執(zhí)行下面的語句,因為HC一般從主函數(shù)傳入
	//HC = (char**)malloc(num*sizeof(char*));
	//逆向求字符編碼,首先將工作空間用字符串結束標志初始化:
	workSpace[num-1] = '\0';
	//雙重循環(huán)依次對各個字符求編碼 
	for(i = 0; i < num ; ++i){
		start = num -1;
		//循環(huán)結束標志是結點的雙親結點為0,也即到達了根結點了
		for(temp = i,par = HT[i].parent;     par != 0;      temp = par,par = HT[par].parent)
			if(HT[par].lchild == temp)
				workSpace[--start] = '0';
			else
				workSpace[--start] = '1';
			//為當前求得的字符編碼分配適當大小的空間
			*(HC+i) = (char*)malloc((num - start)*sizeof(char));
			//從工作空間拷貝編碼串到分配好的區(qū)域中
			strcpy( *(HC+i) , &workSpace[start]);
	}
	//釋放工作空間
	free(workSpace);
}
void huffmanCoding()
{
	int i=0;
	double temp=0;
	FILE* p=fopen("hfm.txt","r");
	FILE* fp=fopen("code.txt","w");
	while(1)
	{
		fscanf(p,"%lf",&temp);
		for(i=0;i<n;i++)
		{
			if(data[i][1]==temp)
			{
				fprintf(fp,"%s\n",HC[i]);
				break;
			}
		}
		if(feof(p))break;
	}
	fclose(p);
	fclose(fp);
}
void dhuffmanCoding()
{
	int i=0;
	long int m=0,k=0;
	char temp[20];	
	FILE* p=fopen("code.txt","r");
	FILE* fp=fopen("data.txt","w");
	while(1)
	{
		memset(temp,0,20);
		fgets(temp,20,p);
		if(feof(p))break;
		m=atoi(temp);
		for(i=0;i<n;i++)
		{
			k=atoi(HC[i]);
			if(m==k)
			{
				fprintf(fp,"%f\n",data[i][1]);
				break;
			}
		}
	}
	fclose(p);
	fclose(fp);
}
void show()
{
	printf("\n\t\t-************************************-\n");
	printf("\t\t-* 此程序演示哈夫曼編碼以及譯碼過程 *-\n");
	printf("\t\t-* www.coolboys.cn  Design by cooky *-\n");
	printf("\t\t-************************************-\n");
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人精品网址| 国产乱人伦偷精品视频不卡| 国产成人av福利| 国产精品一区在线观看乱码| 日本韩国欧美一区二区三区| 成人免费精品视频| 国产在线精品免费av| 国产一区二区成人久久免费影院| 精品在线观看视频| 天天综合天天做天天综合| 婷婷综合另类小说色区| 国产精品77777| 国产三级一区二区| 欧美高清性hdvideosex| 精品视频色一区| 欧美日韩夫妻久久| 日韩欧美第一区| 精品国产乱码久久久久久夜甘婷婷 | 久久综合视频网| www久久久久| 国产日韩av一区| 国产精品美女久久久久久久久 | 欧美一级精品大片| 精品久久久久久久久久久久包黑料 | 欧美变态tickle挠乳网站| 欧美大片日本大片免费观看| 2020日本不卡一区二区视频| 国产精品水嫩水嫩| 一级精品视频在线观看宜春院| 性久久久久久久久久久久| 美女视频免费一区| 国产**成人网毛片九色 | 国产美女精品人人做人人爽| 欧美日本高清视频在线观看| 一区二区视频在线| 久久夜色精品一区| 香蕉影视欧美成人| 91色视频在线| 一区二区不卡在线视频 午夜欧美不卡在 | 国产成人精品影视| 欧美成人三级电影在线| 粉嫩在线一区二区三区视频| 亚洲蜜臀av乱码久久精品| 视频精品一区二区| 99视频一区二区| 欧美一区二区在线视频| 中文字幕欧美一| 久久国产乱子精品免费女| 91麻豆国产自产在线观看| 日韩一区二区三区在线观看| 成人欧美一区二区三区在线播放| 亚洲第一主播视频| 不卡的电影网站| 久久男人中文字幕资源站| 一区二区三区影院| 成人激情午夜影院| 精品国产人成亚洲区| 日韩影院精彩在线| 99久久婷婷国产综合精品电影| 欧美va亚洲va国产综合| 亚洲一区二区美女| 色94色欧美sute亚洲线路一久| 久久久国产精品不卡| 久久99精品久久久| 欧美夫妻性生活| 午夜精品一区二区三区三上悠亚| av不卡免费在线观看| 亚洲国产精品t66y| 国产精品一级黄| 久久综合色婷婷| 国产资源在线一区| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 亚洲另类春色国产| 成人免费视频caoporn| 久久精子c满五个校花| 精品在线免费观看| 2017欧美狠狠色| 国模套图日韩精品一区二区| 日韩美女主播在线视频一区二区三区| 性感美女久久精品| 欧美一区在线视频| 久久精品国产亚洲a| 国产iv一区二区三区| 欧美精品精品一区| 精品国精品国产尤物美女| 日本在线不卡视频| 日韩欧美国产三级| 激情国产一区二区| 久久欧美一区二区| 国产.欧美.日韩| 亚洲乱码中文字幕| 欧美喷水一区二区| 精品一区二区日韩| 国产精品蜜臀av| 日本韩国一区二区三区视频| 亚洲高清三级视频| 欧美mv日韩mv国产网站app| 国产一区二区三区| 亚洲欧美日韩国产手机在线| 在线影院国内精品| 久久狠狠亚洲综合| 欧美激情在线观看视频免费| 在线看日本不卡| 麻豆精品一区二区三区| 国产精品美女久久久久久久久久久 | 精品一区二区三区不卡| 国产精品美女久久久久久2018| 一本色道亚洲精品aⅴ| 爽好久久久欧美精品| 久久久三级国产网站| 99久久婷婷国产综合精品| 午夜精品一区二区三区电影天堂| 久久午夜电影网| 在线观看国产91| 狠狠色狠狠色综合日日91app| 亚洲欧洲成人av每日更新| 69堂国产成人免费视频| 成人性生交大片免费看在线播放 | 日韩精品乱码免费| 国产精品日日摸夜夜摸av| 欧美亚洲精品一区| 国产超碰在线一区| 日本中文字幕一区二区视频| 中文字幕av一区二区三区高| 欧美色区777第一页| 国产成人综合网| 午夜成人免费视频| 一区二区三区日韩在线观看| 亚洲精品一线二线三线| 欧美日韩免费一区二区三区| 成人午夜在线播放| 国产在线视视频有精品| 天堂久久久久va久久久久| 亚洲欧美日韩小说| 国产精品视频一二三区| 精品少妇一区二区三区在线播放| 日本精品视频一区二区三区| 成人免费观看av| 国产成人精品午夜视频免费| 美国一区二区三区在线播放| 亚洲一二三区不卡| 日韩伦理电影网| 日韩毛片在线免费观看| 欧美国产一区在线| 久久毛片高清国产| 日韩欧美国产一区二区三区| 综合激情成人伊人| 亚洲一区在线视频| 国产精品短视频| 国产精品毛片高清在线完整版| 精品美女被调教视频大全网站| 这里只有精品电影| 日韩久久精品一区| 日韩精品专区在线| 久久久亚洲欧洲日产国码αv| 26uuu久久天堂性欧美| 国产日韩一级二级三级| 2019国产精品| 国产欧美日韩不卡免费| 国产三级欧美三级日产三级99 | 国产精品国产自产拍高清av| 久久久不卡网国产精品一区| 国产亚洲美州欧州综合国| 久久精品人人做人人爽97| 久久一二三国产| 色94色欧美sute亚洲13| 国产mv日韩mv欧美| 奇米影视在线99精品| 午夜精品久久久久影视| 亚洲女人****多毛耸耸8| 中文字幕+乱码+中文字幕一区| 在线看日本不卡| 91久久久免费一区二区| 91蝌蚪porny| 国产精品视频yy9299一区| 日韩丝袜情趣美女图片| 久久精品一区二区三区四区| 亚洲成av人综合在线观看| 日韩视频一区二区三区| 欧美日韩一区二区三区在线看| 国产精品1区二区.| 99精品热视频| 在线视频观看一区| 欧美疯狂做受xxxx富婆| 久久蜜桃一区二区| 成人污视频在线观看| 亚洲成人高清在线| 欧美一区二区精品在线| 国产成人精品免费看| 福利一区在线观看| 欧美日韩一区二区不卡| 欧美tickling网站挠脚心| 亚洲欧美一区二区不卡| 日韩国产欧美三级| 国产成人午夜99999| 欧美日韩成人综合| 国产精品视频免费看| 亚洲成av人片www| 国产99精品国产| 欧美精品在线一区二区|