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

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

?? huffypacker.cpp

?? 有關huffman的程序對大家學習數(shù)據(jù)結構有好處但不是所有人都用得上
?? CPP
字號:
// HuffyPacker.cpp: implementation of the HuffyPacker class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "HuffmanTest.h"
#include "HuffyPacker.h"

#include "HuffmanCoder.h"
#include "HuffyDict.h"

#include <sys/types.h>
#include <sys/stat.h>

#include <string>

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

HuffyPacker::HuffyPacker()
{
	InFN=OutFN=NULL;

	MyLog=NULL;
	MyListener=NULL;
}

HuffyPacker::~HuffyPacker()
{
	delete[] InFN;
	delete[] OutFN;
}

void HuffyPacker::SetUIHelpers(ProgressListener *NewListener, WinLog *NewLogTarget)
{
	MyListener=NewListener;
	MyLog=NewLogTarget;
}

void HuffyPacker::SetFileNames(const char *InFileName, const char *OutFileName)
{
	delete[] InFN;
	unsigned short FNLen=strlen(InFileName);
	InFN=new char[FNLen+1];
	strcpy(InFN,InFileName);
	InFN[FNLen]='\0';

	delete[] OutFN;
	FNLen=strlen(OutFileName);
	OutFN=new char[FNLen+1];
	strcpy(OutFN,OutFileName);
	OutFN[FNLen]='\0';
}

unsigned int HuffyPacker::ThreadEncoder(void *Self)
{
	return ((HuffyPacker *)Self)->Encode();
}

unsigned int HuffyPacker::ThreadDecoder(void *Self)
{
	return ((HuffyPacker *)Self)->Decode();
}

unsigned int HuffyPacker::Encode()
{
	if ((!MyListener) || (!MyLog))
		return 2;

	char TmpBuff[64];
	sprintf(TmpBuff,"Huffy packer v%d.%2d started.",HUFFYMAJORVER,HUFFYMINORVER);
	MyLog->LogText(TmpBuff);

	FILE *InFile=Loggedfopen(InFN,true);
	if (!InFile)
		return 1;
	unsigned int InFileLength=GetFileLength(InFN);

	MyLog->LogText("Creating adaptive dictionary...");
	MyListener->SetMax(InFileLength);
	MyListener->SetProgressMsg("Counting: %d%%");

	HuffyDict CurrDict;
	CurrDict.SetUIHelper(MyListener);
	CurrDict.CreateAdaptedDict(InFile);

	fclose(InFile);

	unsigned char MaxLen,MinLen;
	MyLog->LogText("Dictionary stats:");
	sprintf(TmpBuff,"  Symbol count: %d",CurrDict.GetStats(MaxLen,MinLen));
	MyLog->LogText(TmpBuff);
	sprintf(TmpBuff,"  Min / Max code length: %d / %d",MinLen,MaxLen);
	MyLog->LogText(TmpBuff);

	InFile=Loggedfopen(InFN,true);
	FILE *OutFile=Loggedfopen(OutFN,false);
	if ((!InFile) || (!OutFile))
		return 1;

	MyLog->LogText("Writing packed file...");
	//First, write the header...
	WritePackedHeader(OutFile,InFileLength);
	//...then the dictionary...
	MyLog->LogText("  Writing dictionary...");
	CurrDict.Serialize(OutFile);

	//...and finally, the encoded file itself.
	MyLog->LogText("  Encoding source file...");
	MyListener->SetProgressMsg("Encoding: %d%%");
	MyListener->Reset();

	HuffmanCoder MyCoder;
	MyCoder.SetProgressHelper(MyListener);
	MyCoder.SetEncDict(&CurrDict);
	MyCoder.Encode(InFile,OutFile);

	fclose(InFile);
	fclose(OutFile);
	
	MyListener->Reset();
	MyLog->LogText("Packing finished.");
	sprintf(TmpBuff,"Compression ratio was %.2f",GetFileLength(OutFN)/(float)InFileLength);
	MyLog->LogText(TmpBuff);

	return 0;
}

unsigned int HuffyPacker::Decode()
{
	if ((!MyListener) || (!MyLog))
		return 2;

	char TmpBuff[64];
	sprintf(TmpBuff,"Huffy packer v%d.%2d started.",HUFFYMAJORVER,HUFFYMINORVER);
	MyLog->LogText(TmpBuff);

	FILE *InFile=Loggedfopen(InFN,true);
	if (!InFile)
		return 1;
	unsigned int InFileLength=GetFileLength(InFN);

	unsigned int OrigSize;
	unsigned char HeaderRet=ReadPackedHeader(InFile,OrigSize);
	if (HeaderRet==1)
	{
		MyLog->LogText("Input file is not Huffy-compressed.");
		return 2;
	}
	else if (HeaderRet==2)
	{
		MyLog->LogText("Input file was compressed by another Huffy version.");
		return 2;
	}

	MyLog->LogText("Reading dictonary...");
	
	HuffyDict CurrDict;
	CurrDict.SetUIHelper(MyListener);
	CurrDict.Deserialize(InFile);

	MyLog->LogText("Generating node transition table...");
	unsigned int StateCount;
	CurrDict.GetNTTable(StateCount);

	sprintf(TmpBuff,"  State count: %d",StateCount);
	MyLog->LogText(TmpBuff);

	FILE *OutFile=Loggedfopen(OutFN,false);
	if (!OutFile)
		return 1;

	MyLog->LogText("Decoding source file...");
	MyListener->SetProgressMsg("Decoding: %d%%");
	MyListener->SetMax(OrigSize);

	HuffmanCoder MyCoder;
	MyCoder.SetProgressHelper(MyListener);
	MyCoder.SetDecDict(&CurrDict);
	MyCoder.Decode(InFile,OutFile,OrigSize);

	
	fclose(InFile);
	fclose(OutFile);
	MyListener->Reset();
	MyLog->LogText("Unpacking finished.");

	return 0;
}

void HuffyPacker::WritePackedHeader(FILE *TargetFile, unsigned int OrigSize)
{
	fwrite("Huffy",5,1,TargetFile);

	unsigned char MajVer=HUFFYMAJORVER, MinVer=HUFFYMINORVER;
	fwrite(&MajVer,1,1,TargetFile);
	fwrite(&MinVer,1,1,TargetFile);

	fwrite(&OrigSize,4,1,TargetFile);
}

unsigned char HuffyPacker::ReadPackedHeader(FILE *SourceFile, unsigned int &RetOrigSize)
{
	char HeaderTmp[5];
	fread(HeaderTmp,5,1,SourceFile);

	//Header mismatch.
	if (memcmp("Huffy",HeaderTmp,5))
		return 1;

	unsigned char MajVer,MinVer;
	fread(&MajVer,1,1,SourceFile);
	fread(&MinVer,1,1,SourceFile);

	//Archive version mismatch.
	if ((MajVer!=HUFFYMAJORVER) || (MinVer!=HUFFYMINORVER))
		return 2;

	fread(&RetOrigSize,4,1,SourceFile);
	return 0;
}

unsigned int HuffyPacker::GetFileLength(const char *FileName)
{
	//Ugly and not portable.
	struct _stat TmpOut;
	_stat(FileName,&TmpOut);
	return TmpOut.st_size;
}

FILE *HuffyPacker::Loggedfopen(const char *FileName, bool Read)
{
	FILE *RetFile;
	if (Read)
		RetFile=fopen(FileName,"rb");
	else
		RetFile=fopen(FileName,"wb");

	if (RetFile)
	{
		std::string TmpMsg="Opened file \"";
		TmpMsg+=FileName;
		TmpMsg+="\" for ";
		if (Read)
			TmpMsg+="reading.";
		else
			TmpMsg+="writing.";

		MyLog->LogText(TmpMsg.data());
	}
	else
	{
		std::string TmpMsg="FAILED to open file \"";
		TmpMsg+=FileName;
		TmpMsg+="\" for ";
		if (Read)
			TmpMsg+="reading!";
		else
			TmpMsg+="writing!";

		MyLog->LogText(TmpMsg.data());
	}

	return RetFile;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆国产精品一区二区三区 | 亚洲色图欧洲色图| 国产一区二区精品久久| 久久精品在这里| 懂色av一区二区三区免费看| **欧美大码日韩| 欧美综合久久久| 日韩电影一区二区三区四区| 精品理论电影在线| 高清不卡一区二区| 亚洲精品久久久久久国产精华液| 欧美亚洲愉拍一区二区| 日韩中文字幕区一区有砖一区| 日韩一区二区在线观看视频| 国产成人精品免费| 亚洲激情自拍视频| 制服丝袜亚洲网站| 粉嫩一区二区三区性色av| 亚洲精品欧美综合四区| 日韩三级视频中文字幕| 成人av电影免费在线播放| 亚洲福利一二三区| 久久免费美女视频| 色乱码一区二区三区88| 美女视频免费一区| 中文字幕一区二| 日韩视频免费观看高清完整版| 国产东北露脸精品视频| 亚洲福中文字幕伊人影院| 久久久久99精品国产片| 精品污污网站免费看| 国产精品456| 亚洲一卡二卡三卡四卡无卡久久| 精品成人a区在线观看| 欧美中文字幕一二三区视频| 国模大尺度一区二区三区| 一区二区三区免费在线观看| 精品国产免费人成在线观看| 欧美视频第二页| 国产成人精品网址| 麻豆专区一区二区三区四区五区| 亚洲色图欧洲色图婷婷| 国产亚洲综合在线| 91.com在线观看| 91麻豆免费观看| 国产剧情一区二区三区| 日韩在线播放一区二区| 亚洲人成人一区二区在线观看| 精品国产伦一区二区三区免费| 在线看国产日韩| www.日韩精品| 国产精品一区不卡| 久草在线在线精品观看| 无码av免费一区二区三区试看| 国产精品久久久久aaaa樱花| 久久综合色8888| 欧美一级二级在线观看| 欧美日韩和欧美的一区二区| 97精品国产97久久久久久久久久久久 | 亚洲一区日韩精品中文字幕| 久久久91精品国产一区二区精品 | 日本不卡1234视频| 亚洲成a人片综合在线| 国产精品麻豆视频| 日本一区二区三区久久久久久久久不| 91精品国产高清一区二区三区| 欧美午夜一区二区三区| 91久久精品国产91性色tv| 成人激情开心网| 国产99久久精品| 国产精华液一区二区三区| 久久国产精品免费| 精品一区二区三区影院在线午夜| 午夜私人影院久久久久| 亚洲国产综合人成综合网站| 亚洲一区中文在线| 亚洲自拍欧美精品| 一个色综合av| 亚洲成人在线网站| 午夜精品久久久久| 丝袜a∨在线一区二区三区不卡| 夜色激情一区二区| 亚洲二区在线观看| 性感美女久久精品| 日av在线不卡| 韩国毛片一区二区三区| 国产精品自拍毛片| 成人激情小说网站| 99久久精品免费看| 日本大香伊一区二区三区| 欧美亚洲图片小说| 69堂成人精品免费视频| 日韩精品一区二区三区视频在线观看| 日韩欧美123| 国产人伦精品一区二区| 国产精品久久久久久福利一牛影视 | 亚洲成av人片一区二区三区| 婷婷久久综合九色综合绿巨人| 蜜臀av在线播放一区二区三区| 激情综合色综合久久综合| 国产成人精品亚洲午夜麻豆| 99亚偷拍自图区亚洲| 欧美综合亚洲图片综合区| 日韩一二三区不卡| 日本一区二区免费在线| 一区二区三区在线视频播放| 日韩精品欧美精品| 丰满少妇在线播放bd日韩电影| 91视频观看视频| 欧美剧情片在线观看| 久久久精品蜜桃| 亚洲一区二区三区精品在线| 韩国精品主播一区二区在线观看| 成人国产亚洲欧美成人综合网| 91精品办公室少妇高潮对白| 欧美电视剧免费全集观看| 中文字幕在线不卡国产视频| 五月婷婷欧美视频| 国产成人av资源| 欧美精品乱人伦久久久久久| 久久久久久久久久看片| 亚洲成人动漫av| 成人免费视频免费观看| 在线电影院国产精品| 亚洲国产精品成人综合色在线婷婷 | 亚洲激情男女视频| 精品一区二区三区在线播放| 色综合久久综合| 久久久www免费人成精品| 亚洲国产一区视频| youjizz久久| 2022国产精品视频| 亚洲va韩国va欧美va精品| proumb性欧美在线观看| 精品日韩欧美在线| 亚洲午夜日本在线观看| a亚洲天堂av| 26uuu久久天堂性欧美| 性做久久久久久久久| av成人免费在线观看| 欧美电视剧免费全集观看| 亚洲午夜影视影院在线观看| 成人av资源在线| 久久亚洲一区二区三区明星换脸| 亚洲午夜久久久久久久久电影院 | 日本精品一区二区三区四区的功能| 精品国产精品网麻豆系列| 午夜精品福利一区二区三区av | 韩国精品在线观看| 日韩一区二区免费电影| 亚洲一区二区三区爽爽爽爽爽| www.欧美.com| 国产精品久久久久aaaa| 国产风韵犹存在线视精品| 精品国产乱码91久久久久久网站| 日一区二区三区| 欧美日韩国产影片| 亚洲一区二区三区免费视频| 一本到高清视频免费精品| 一区免费观看视频| 99久久精品情趣| 亚洲视频一二三区| jiyouzz国产精品久久| 国产精品视频你懂的| 欧美一级高清大全免费观看| 亚洲国产精品天堂| 欧美日韩国产在线观看| 亚洲二区在线观看| 欧美精品一级二级三级| 五月婷婷激情综合网| 欧美高清视频在线高清观看mv色露露十八 | 日本欧美一区二区三区| 6080午夜不卡| 久久国产剧场电影| 久久久夜色精品亚洲| 国产成人av电影在线| 国产精品欧美极品| 色综合天天狠狠| 亚洲综合免费观看高清完整版在线 | 亚洲综合视频网| 欧美男女性生活在线直播观看| 婷婷六月综合亚洲| 精品日韩成人av| 国产成人鲁色资源国产91色综| 国产精品女同互慰在线看| 91麻豆福利精品推荐| 亚洲电影在线免费观看| 日韩一区二区三区三四区视频在线观看 | 欧美视频中文字幕| 蜜桃一区二区三区在线| 久久久精品综合| av毛片久久久久**hd| 亚洲永久免费av| 欧美大片在线观看| 成a人片国产精品| 亚洲成人动漫在线观看| 欧美v亚洲v综合ⅴ国产v| 成人午夜视频福利| 亚洲午夜激情网站| 精品国产乱码91久久久久久网站|