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

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

?? huffma那.cpp

?? 根據信源壓縮編碼——Huffman編碼的原理
?? CPP
字號:
#include <iostream.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <math.h>

#define MaxValue 10000
#define MaxBit 10
#define MaxN 100

struct letter
{
	
	char a;
	int num;
	
}lett[26];
char text[100];
char code[100];
int code_save[100];

typedef struct  
{
	int weight;
	int flag;
	int parent;
	int leftchild;
	int rightchild;
}HaffNode;

typedef struct
{
	
	int bit[MaxN];
	int start;
	int weight;
}Code;





void Haffman(int weight[],int n,HaffNode haffTree[])
{
	
	int i,j,m1,m2,x1,x2;
	for(i=0;i<2*n-1;i++)//initial
	{
		
		if (i<n)haffTree[i].weight=weight[i];
		else haffTree[i].weight=0;
		haffTree[i].parent=-1;
		haffTree[i].flag=0;
		haffTree[i].leftchild=-1;
		haffTree[i].rightchild=-1;
	}
	
	for (i=0;i<n-1;i++)//search for the least weight dot
	{
		m1=m2=MaxValue;
		x1=x2=0;
		for(j=0;j<n+i;j++)
		{
			
			if (haffTree[j].weight<m1&&haffTree[j].flag==0)
			{
				m2=m1;
				x2=x1;
				m1=haffTree[j].weight;
				x1=j;
			}
			else if (haffTree[j].weight<m2&&haffTree[j].flag==0)
			{
				m2=haffTree[j].weight;
				x2=j;
			}
		}
		haffTree[x1].parent=n+i;
		haffTree[x2].parent=n+i;
		haffTree[x1].flag=1;
		haffTree[x2].flag=1;
		haffTree[n+i].weight=haffTree[x1].weight+haffTree[x2].weight;
		haffTree[n+i].leftchild=x1;
		haffTree[n+i].rightchild=x2;
	}
}

void HaffmanCode(HaffNode haffTree[],int n,Code haffCode[])
{
	Code *cd=(Code *)malloc(sizeof(Code));
	int i,j,child,parent;
	
	for(i=0;i<n;i++)
	{
		
		cd->start=n-1;
		cd->weight=haffTree[i].weight;
		child=i;
		parent=haffTree[child].parent;
		
		while (parent!=-1)
		{
			if (haffTree[parent].leftchild==child)
				cd->bit[cd->start]=0;
			else
				cd->bit[cd->start]=1;
			
			cd->start--;
			child=parent;
			parent=haffTree[child].parent;
			
		}
		for(j=cd->start+1;j<n;j++)
			haffCode[i].bit[j]=cd->bit[j];
		haffCode[i].start=cd->start+1;
		haffCode[i].weight=cd->weight;
	}
}



void decode(HaffNode tree[])
{
	int i,j,m,k=0;
	char ch;
	FILE *fp;
	m=2*26-2;
	i=m;
//	load();
	printf("\nDecode:\n");
	k=0;
	while(code_save[k]!=10)   //遇到回車時,結束
	{
		
		if(code_save[k]==0)i=tree[i].leftchild;
		else i=tree[i].rightchild;
		if(tree[i].leftchild==-1)
		{
			printf("%c",lett[i].a);
			j=i,i=m;
			
		}k++;

	}
	if(tree[j].leftchild!=-1)
		printf("\nERROR\n");
	printf("\n\n");
}


void main()
{
	
	int k,temp,m=0;
	int i=0,j; 
	FILE *fp;
	char ch;
	fp=fopen("text.txt","r"); 
	ch=fgetc(fp);
	while(ch!=EOF)
	{
		text[i]=ch;
		i++;
		ch=fgetc(fp);
	}
	fclose(fp);
    i=0;
	for (k=0;k<26;k++)
	{
		lett[k].a=k+97;
		lett[k].num=0;
	}
	while(text[i]!=10)
	{
		for (int j=0;j<26;j++)
		{
			if(lett[j].a==text[i])
			{
				lett[j].num++;
				break;
			}
		}
		i++;
	}
	
	int weight[26];
	
	for(k=0;k<26;k++)
	{
		weight[k]=lett[k].num;
	}
	
	HaffNode *myHaffTree=(HaffNode*)malloc(sizeof(HaffNode)*(2*26+1));
	Code *myHaffCode=(Code *)malloc(sizeof(Code)*26);
	
	Haffman(weight,26,myHaffTree);
	HaffmanCode(myHaffTree,26,myHaffCode);
	//k=0;
	for(i=0;i<26;i++)
	{
		printf("letter=%c    weight=%d     code=",lett[i].a,myHaffCode[i].weight);
		for (j=myHaffCode[i].start;j<26;j++)
		{
			printf("%d",myHaffCode[i].bit[j]);
		//	code_save[k]=myHaffCode[i].bit[j];
		//	k++;
		}
		printf("\n");
	}
	i=0;k=0;
	while (text[i]!=10)
	{
		while(text[i]!=lett[k].a)k++;
		
		if (text[i]==lett[k].a)
		{
			for (j=myHaffCode[k].start;j<26;j++)
				
				//break;
			{
				temp=myHaffCode[k].bit[j];
               code_save[m]=temp;
			   m++;
				
				printf("%d",temp);
			}
			
		}
		k=0;
		i++;
	}
	code_save[m]=10;
//	save();
	decode(myHaffTree);
}



void load()
{
	char ch;
	FILE *fp;
	int i;
	if((fp=fopen("code.txt","r"))==NULL)
	{
		printf("\n無法打開文件code.txt!\n");
		return ;
	}
	for(i=0;!feof(fp);i++)
		fread(&code[i],1,1,fp);
	fclose(fp);
}

void save()
{
	
	FILE *fp;
	int i=0;
	if((fp=fopen("code.txt","w"))==NULL)
	{
		printf("\n無法打開文件code.txt!\n");
		return;
	}
	while(code_save[i]!=10)
	{
		if((fwrite(&code_save[i],2,1,fp))!=1)
			//	printf("文件code.txt寫入錯誤\n");
			i++;
	}
	
	fclose(fp);
	
}







?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美军同video69gay| 久久久久青草大香线综合精品| 欧美一级黄色大片| 国产精品视频第一区| 日韩高清一区在线| 欧美亚洲国产一卡| 国产精品成人免费精品自在线观看| 秋霞电影网一区二区| 色综合中文字幕国产 | 精品久久国产老人久久综合| 亚洲天堂免费在线观看视频| 国内精品久久久久影院色| 欧美无乱码久久久免费午夜一区| 中文字幕乱码亚洲精品一区| 国内精品国产三级国产a久久| 91麻豆精品国产自产在线观看一区| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | av亚洲精华国产精华| 精品播放一区二区| 久久精品999| 欧美日韩国产综合一区二区三区 | 亚洲成av人片在www色猫咪| 91麻豆成人久久精品二区三区| 国产午夜精品一区二区三区视频| 日韩国产欧美视频| 91精品国产一区二区三区| 亚洲电影一级片| 在线观看av一区二区| 亚洲三级在线观看| 99久久伊人精品| 亚洲视频一二区| 91美女精品福利| 一区二区在线观看视频在线观看| 99久久99久久综合| 亚洲欧美自拍偷拍色图| 不卡av在线免费观看| 国产精品乱人伦一区二区| 成人久久18免费网站麻豆 | 成人一区二区三区视频| 欧美激情综合五月色丁香小说| 国产福利一区在线观看| 国产欧美精品一区二区三区四区 | 久久99精品久久久久久国产越南| 欧美成人女星排名| 国产高清精品久久久久| 国产日韩高清在线| 一本色道久久综合亚洲91| 亚洲一区二区三区影院| 欧美一二三四在线| 国产精品一区久久久久| 中文字幕+乱码+中文字幕一区| 国产成人在线视频网站| 国产精品久久久久久久久免费丝袜| 成人av电影免费观看| 一区二区在线免费观看| 日韩免费电影网站| 国产高清久久久久| 一区二区三区欧美日| 欧美一级欧美一级在线播放| 国精产品一区一区三区mba视频| 中文字幕不卡在线| 欧美日韩中字一区| 国产一区二区在线电影| 亚洲欧美视频在线观看视频| 欧美性猛交一区二区三区精品| 麻豆精品在线视频| 亚洲精品成人精品456| 欧美一级免费大片| 成人黄色软件下载| 五月天视频一区| 国产精品色婷婷久久58| 在线不卡中文字幕| 成人av先锋影音| 免费欧美高清视频| 亚洲欧美福利一区二区| 欧美大片在线观看一区| av一区二区三区四区| 久久国产精品无码网站| 一级女性全黄久久生活片免费| 精品国产1区二区| 91成人在线精品| 国产成人av福利| 日韩av电影天堂| 亚洲男女一区二区三区| 久久久久99精品一区| 欧美美女黄视频| 99国产精品久久久久| 国产成人精品亚洲午夜麻豆| 日韩在线观看一区二区| 国产欧美一区二区精品性色 | 色综合色狠狠综合色| 国产一区二区三区四区五区美女 | 精品无码三级在线观看视频| 亚洲一区在线观看网站| 国产精品国产a| 久久久久青草大香线综合精品| 欧美精品aⅴ在线视频| 色偷偷久久人人79超碰人人澡| 国产精品一区二区在线观看网站 | 亚洲观看高清完整版在线观看| 国产精品视频第一区| 久久久精品影视| 久久在线观看免费| 日韩欧美一区二区三区在线| 欧美日韩一区二区三区高清| 91看片淫黄大片一级在线观看| 粉嫩aⅴ一区二区三区四区五区| 久久www免费人成看片高清| 日本不卡123| 日韩成人午夜电影| 奇米四色…亚洲| 日本欧美在线观看| 久久精品国产久精国产| 经典一区二区三区| 久久99国产精品麻豆| 老汉av免费一区二区三区| 337p亚洲精品色噜噜| 风间由美中文字幕在线看视频国产欧美 | 国产精品免费看片| 国产精品麻豆欧美日韩ww| 国产精品国模大尺度视频| 欧美国产日韩亚洲一区| 国产精品美女www爽爽爽| 国产精品网曝门| 亚洲欧美日韩成人高清在线一区| 亚洲女厕所小便bbb| 亚洲伊人色欲综合网| 天天综合色天天综合| 免费精品视频最新在线| 韩国中文字幕2020精品| 国产精品1区二区.| 91在线视频网址| 欧美视频精品在线观看| 欧美一级久久久| 欧美激情一区在线| 亚洲欧美日本韩国| 日本三级亚洲精品| 国产成人在线观看| 色8久久精品久久久久久蜜| 777久久久精品| 久久久久9999亚洲精品| 日韩久久一区二区| 天堂一区二区在线免费观看| 激情深爱一区二区| 97精品国产露脸对白| 欧美日韩国产电影| 久久蜜臀精品av| 亚洲精品国产精品乱码不99 | 亚洲国产精品精华液网站| 久久国产福利国产秒拍| 成人黄色片在线观看| 欧美精品18+| 国产精品视频在线看| 亚洲国产综合视频在线观看| 毛片av一区二区三区| 不卡区在线中文字幕| 欧美一区二区三区视频免费播放| 国产精品色一区二区三区| 天堂va蜜桃一区二区三区漫画版| 国产精品一区二区在线观看网站| 欧美亚洲动漫另类| 国产欧美日韩亚州综合| 日本欧美一区二区三区乱码| 不卡的电影网站| 日韩欧美国产一二三区| 亚洲三级小视频| 国产一区二区不卡在线| 7777精品伊人久久久大香线蕉的| 中文字幕av在线一区二区三区| 三级一区在线视频先锋| 97久久久精品综合88久久| 欧美成人免费网站| 亚洲国产精品麻豆| 99久久精品久久久久久清纯| 欧美xxxxx裸体时装秀| 亚洲永久免费av| 91视频观看免费| 国产精品色哟哟| 国产丶欧美丶日本不卡视频| 欧美一级久久久久久久大片| 亚洲国产另类av| 91蝌蚪porny九色| 亚洲欧美综合另类在线卡通| 国产乱国产乱300精品| 日韩一级免费观看| 日韩国产精品大片| 欧美男男青年gay1069videost | 日日夜夜免费精品| 欧美日韩亚洲丝袜制服| 亚洲精品成a人| 一区二区三区美女| 久久草av在线| 欧美成人精品1314www| 免费视频一区二区| 91精品啪在线观看国产60岁| 亚洲国产视频网站| 欧美日本在线一区| 五月婷婷久久丁香| 日韩一区二区三区免费观看| 日韩二区三区在线观看|