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

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

?? lzwcode.cpp

?? 加密、安全、壓縮處理
?? CPP
字號(hào):
#include "stdafx.h"
#include "stdio.h"
#include "memory.h"
#include "assert.h"
#include "lzwtable.h"
#include "lzwcode.h"

/*
CDecodeBitArray
*/
CDecodeBitArray::CDecodeBitArray(DWORD dwInitWidth)// width in bit
{
	m_pbBits=NULL;
	m_dwWidthInByte=0;
	m_dwTail=m_dwHead=0;
	if(dwInitWidth)
		InitBits(dwInitWidth);
}
CDecodeBitArray::~CDecodeBitArray()
{
	ClearBits();
}
void CDecodeBitArray::ClearBits(void)
{
	if(m_pbBits)
		delete m_pbBits;
	m_dwTail=m_dwHead=0;
	m_dwWidthInByte=0;
}
void CDecodeBitArray::InitBits(DWORD dwInitWidth)
{
	ClearBits();
	DWORD dwLength=dwInitWidth/8;
	dwLength+=(dwInitWidth%8)?1:0;
	m_pbBits=new BYTE[dwLength];
	m_dwHead=m_dwTail=0;
	m_dwWidthInByte=dwLength;
}
void CDecodeBitArray::InitBytes(DWORD dwInitWidth)
{
	InitBits(dwInitWidth*8);
}
DWORD CDecodeBitArray::GetLeftBytes(void)
{
	DWORD dwLeftBytes;
	DWORD dwLeftBits=GetLeftBits();
	dwLeftBytes=dwLeftBits/8;
	dwLeftBytes+=(dwLeftBits%8)?1:0;
	return dwLeftBytes;
}
WORD CDecodeBitArray::RemoveBits(int iWidth)
{
	WORD wGet=0;
	for(int i=iWidth-1;i>=0;i--)
	{
		if(RemoveFirstBit())
			SET_BIT_1(wGet,i);
	}
	return wGet;
}
WORD CDecodeBitArray::RemoveFirstBit(void)
{
	BYTE* pbFirstByte=m_pbBits+m_dwHead/8;
	BYTE bFirstByte=*pbFirstByte;
	WORD wGet=(CHECK_BIT_1(bFirstByte,7-m_dwHead%8))?1:0;
	m_dwHead++;
	return wGet;
}
BOOL CDecodeBitArray::AddBytes(BYTE* pbAdd,int iLength)
{
	if(m_pbBits==NULL)
		return FALSE;
	Resort();
	memcpy(m_pbBits+m_dwTail/8,pbAdd,iLength);
	m_dwTail+=8*(DWORD)iLength;
	return TRUE;
}
void CDecodeBitArray::Resort(void)
{// because m_dwTail%8 always equal 0
	if(m_dwHead<8)
		return;
	if(m_dwTail==m_dwHead)
	{
		m_dwTail=m_dwHead=0;
		return;
	}
	DWORD dwLength=GetLeftBytes();
	DWORD dwHead=m_dwHead%8;
	DWORD dwMove=m_dwHead-dwHead;
	memcpy(m_pbBits,m_pbBits+(m_dwHead/8),(int)dwLength);
	m_dwHead=dwHead;
	m_dwTail-=dwMove;
}

/*
class CEncodeBitArray
*/
CEncodeBitArray::CEncodeBitArray(DWORD dwInitWidth)
{
	if(dwInitWidth==0)
		m_pbBits=NULL;
	else
		InitBits(dwInitWidth);
}
CEncodeBitArray::~CEncodeBitArray()
{
	ClearBits();
}
BOOL CEncodeBitArray::InitBits(DWORD dwInitWidth)
{
	ClearBits();
	assert(dwInitWidth);
	m_dwWidthInByte=dwInitWidth/8;
	m_dwWidthInByte+=(dwInitWidth%8)?1:0;
	m_pbBits=new BYTE[m_dwWidthInByte];
	m_dwTail=0;
	return TRUE;
}
void CEncodeBitArray::ClearBits(void)
{
	if(m_pbBits)
		delete m_pbBits;
	m_pbBits=NULL;
}
BOOL CEncodeBitArray::AddBits(WORD wAdd,int iWidth)
{
	if(m_pbBits==NULL)
		return FALSE;
	for(int i=iWidth-1;i>=0;i--)
	{
		BYTE* pbByte=m_pbBits+m_dwTail/8;
		if(CHECK_BIT_1(wAdd,i))
			SET_BIT_1(*pbByte,7-m_dwTail%8);
		else
			SET_BIT_0(*pbByte,7-m_dwTail%8);
		m_dwTail++;
	}
	return TRUE;
}
DWORD CEncodeBitArray::GetBytesWidth(void)
{
	DWORD dwBytes=m_dwTail/8;
	dwBytes+=(m_dwTail%8)?1:0;
	return dwBytes;
}
int CEncodeBitArray::RemoveBytes(BYTE *pbGet,int iWant)
{
	if(m_pbBits==NULL)
		return -1;
	int iTotal=(int)GetBytesWidth();
	if(iWant>iTotal)
		iWant=iTotal;
	if(pbGet!=NULL)
		memcpy(pbGet,m_pbBits,iWant);
	memcpy(m_pbBits,m_pbBits+iWant,iTotal-iWant);
	int iTail=(int)m_dwTail;
	iTail-=iWant*8;
	if(iTail<0)
		iTail=0;
	m_dwTail=iTail;
	return iWant;
}
BOOL CLZWDecode::BeginLZWDecode(const DWORD dwLength,// the compressed length
								FUN_LZWDECODEGETNEXTBYTES pfunLZWGetNextBytes,
								FUN_LZWDECODEPUTNEXTBYTE pfunLZWPutNextByte,
								WORD wBuffer,
								FUN_LZWDECODEDBYTES pfunLZWDecodedBytes,
								DWORD dwBytesOnce)
{
	m_dwDecodedByte=0;
	//printf("enter decode press a key\n");
	BYTE *pbNewData=new BYTE[4000],*pbOutData=new BYTE[4000];
	BYTE *pbBuffer=new BYTE[wBuffer];
	BYTE bFirst;
	m_LZWTable.InitLZWTable();
	int iBitWidth=9;
	m_iTotalEntry=LZW_BEGIN_ENTRY;
	BYTE* pbDecodedData;
	WORD wOld,wLastLen;
	m_baContain.InitBits((wBuffer+20)*8);
	int iR=0;
	DWORD dwRead=0;
	while(1)
	{
		if(m_baContain.GetLeftBytes()<5)
		{
			WORD wGetBytes=wBuffer;
			if((DWORD)wGetBytes+dwRead>dwLength)
				wGetBytes=(WORD)(dwLength-dwRead);
			if(wGetBytes!=0)
			{
				pfunLZWGetNextBytes(pbBuffer,wGetBytes);
				m_baContain.AddBytes(pbBuffer,wBuffer);
				dwRead+=wGetBytes;
			}
		}
		int iT=m_iTotalEntry+1;
		iT>>=9;
		iBitWidth=9;
		while(iT>0)
		{
			iT>>=1;
			iBitWidth++;
		}
		WORD wGet=m_baContain.RemoveBits(iBitWidth);
		if(wGet==LZW_END_CODE)
		{
			break;
		}
		if(wGet==LZW_CLEAR_CODE)
		{
			m_LZWTable.InitLZWTable();
			wGet=m_baContain.RemoveBits(9);
			if(wGet==LZW_END_CODE)
				break;
			pbDecodedData=m_LZWTable.GetMatchData(wGet);
			WriteDecode(pbDecodedData,
						pfunLZWPutNextByte,
						pfunLZWDecodedBytes,
						dwBytesOnce);
			wOld=wGet;
			m_iTotalEntry=258;
		}
		else
		{// not clear
			pbDecodedData=m_LZWTable.GetMatchData(wGet);
			if(NULL!=pbDecodedData)
			{// in table
				bFirst=pbDecodedData[2];
				WriteDecode(pbDecodedData,
							pfunLZWPutNextByte,
							pfunLZWDecodedBytes,
							dwBytesOnce);
				if(wOld!=LZW_CLEAR_CODE)
				{// not the first code be read in
					pbDecodedData=m_LZWTable.GetMatchData(wOld);
					wLastLen=*((WORD*)pbDecodedData);
					memcpy(pbNewData,pbDecodedData+2,wLastLen);
					pbNewData[wLastLen]=bFirst;
					m_LZWTable.AddToChild((WORD)m_iTotalEntry,pbNewData,wLastLen+1);
					m_iTotalEntry+=1;
				}
				wOld=wGet;
			}
			else
			{
				pbDecodedData=m_LZWTable.GetMatchData(wOld);
				bFirst=pbDecodedData[2];
				wLastLen=*((WORD*)pbDecodedData);
				memcpy(pbOutData+2,pbDecodedData+2,wLastLen);
				pbOutData[wLastLen+2]=bFirst;
				*((WORD*)pbOutData)=wLastLen+1;
				WriteDecode(pbOutData,
							pfunLZWPutNextByte,
							pfunLZWDecodedBytes,
							dwBytesOnce);
				if(m_iTotalEntry>=4096)
				{
					int _j=0;
				}
				m_LZWTable.AddToChild((WORD)m_iTotalEntry,pbOutData+2,wLastLen+1);
				m_iTotalEntry+=1;
				wOld=wGet;
			}
		}
		//pbDecodedData=table.GetMatchData(wGet);
		//WORD wLen=*((WORD*)pbDecodedData);
		//pbDecodedData+=2;
	}
	delete pbNewData;
	delete pbOutData;
	delete pbBuffer;
	return dwRead==dwLength;
}								
void CLZWDecode::WriteDecode(BYTE* pbWrite,
							FUN_LZWDECODEPUTNEXTBYTE pfunLZWPutNextByte,
							FUN_LZWDECODEDBYTES pfunLZWDecodedBytes,
							DWORD dwBytesOnce)
{
	if(pbWrite==NULL)
		return;
	WORD wLength=*((WORD*)pbWrite);
	pbWrite+=2;
	for(DWORD i=0;i<wLength;i++)
	{
		pfunLZWPutNextByte(*pbWrite);
		pbWrite++;
		if((pfunLZWDecodedBytes!=NULL)
			&& (dwBytesOnce)
			&& (m_dwDecodedByte%dwBytesOnce==0))
		{
			pfunLZWDecodedBytes();
		}
	}
	m_dwDecodedByte+=wLength;
}
void CLZWDecode::EndLZWDecode(FUN_LZWDECODEPUTNEXTBYTE pfunLZWPutNextByte)
{
}

/*
CLZWEncode
*/
BOOL CLZWEncode::BeginLZWEncode(const DWORD dwLength,
								FUN_LZWENCODEGETNEXTBYTE pfunLZWGetNextByte,
								FUN_LZWENCODEPUTNEXTBYTES pfunLZWPutNextBytes,
								WORD wBufferLen,
								FUN_LZWENCODEDBYTES pfunLZWEncodedBytes,
								DWORD dwBytesOnce)
{
	m_dwCompressedLength=0;
	int iBufferLen=wBufferLen;
	BYTE bGet;
	m_LZWTable.InitLZWTable();// init the entry table
	m_baContain.InitBits((iBufferLen+8)*8);// init the bit array
	m_baContain.AddBits(LZW_CLEAR_CODE,9);// add the first clear code
	/// below : begin the algorithm
	PLZWENCODEENTRY pCurrent=m_LZWTable.GetHead();
	int iBitWidth;
	DWORD dwEncoded=0;
	for(DWORD i=0;i<dwLength;i++)
	{// for each byte
		if(!pfunLZWGetNextByte(bGet))
			return FALSE;
		PLZWENCODEENTRY pChild=m_LZWTable.FindMatchChild(bGet,pCurrent);
		if(pChild)
		{// has found the continue
			pCurrent=pChild;
		}
		else
		{// not find write last code & add new entry 
			iBitWidth=GetBitWidth();
			WORD wW=pCurrent->wCode;
			m_baContain.AddBits(wW,iBitWidth);// add last code to buffer
			m_LZWTable.AddToChild(bGet,pCurrent);// add last code to table
			if(m_baContain.GetBytesWidth()>(DWORD)iBufferLen)
			{
				m_dwCompressedLength+=(DWORD)iBufferLen;
				pfunLZWPutNextBytes(m_baContain.GetBits(),iBufferLen);
				m_baContain.RemoveBytes(NULL,iBufferLen);
			}
			if(m_LZWTable.GetTableEntryNumber()>=(m_wMaxEntry-3))
			{
				iBitWidth=GetBitWidth();
				m_baContain.AddBits(LZW_CLEAR_CODE,iBitWidth);
				m_LZWTable.InitLZWTable();
			}
			pCurrent=m_LZWTable.FindMatchChild(bGet,m_LZWTable.GetHead());
		}
		dwEncoded++;
		if(pfunLZWEncodedBytes && dwEncoded==dwBytesOnce)         
		{
			pfunLZWEncodedBytes();
			dwEncoded=0;
		}
	}
	iBitWidth=GetBitWidth();
	m_baContain.AddBits(pCurrent->wCode,iBitWidth);// add last code to buffer
	return TRUE;
}
void CLZWEncode::EndLZWEncode(FUN_LZWENCODEPUTNEXTBYTES pfunLZWPutNextBytes)
{
	int iBitWidth=GetBitWidth();
	m_baContain.AddBits(LZW_END_CODE,iBitWidth);
	m_dwCompressedLength+=m_baContain.GetBytesWidth();
	pfunLZWPutNextBytes(m_baContain.GetBits(),(int)m_baContain.GetBytesWidth());
	m_LZWTable.ClearLZWTable();
	m_baContain.ClearBits();
};
int CLZWEncode::GetBitWidth(void)
{
	int iTotal=(int)m_LZWTable.GetTableEntryNumber();
	iTotal>>=9;
	int iBitWidth=9;
	while(iTotal>0)
	{
		iTotal>>=1;
		iBitWidth+=1;
	}
	return iBitWidth;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
三级不卡在线观看| 综合网在线视频| 91精品国产日韩91久久久久久| 99视频国产精品| av不卡在线观看| 一本大道久久a久久精二百| av日韩在线网站| 日韩精品免费视频人成| 免费观看成人av| 国产米奇在线777精品观看| 国产一区91精品张津瑜| www.一区二区| 欧美在线免费观看视频| 51精品国自产在线| 久久一日本道色综合| 国产午夜精品一区二区三区嫩草 | 国产亚洲欧美日韩日本| 中文子幕无线码一区tr| 一区二区三区在线免费| 午夜精品久久久久影视| 国产在线视频不卡二| 成人激情午夜影院| 欧美三级在线视频| 久久亚洲二区三区| 亚洲视频小说图片| 麻豆一区二区在线| 成人深夜在线观看| 欧美肥妇bbw| 国产欧美精品一区二区三区四区| 亚洲精品视频免费看| 男女性色大片免费观看一区二区 | 久久麻豆一区二区| 亚洲精品视频自拍| 精品一区二区久久| 在线亚洲一区观看| 国产亚洲欧美日韩在线一区| 亚洲尤物视频在线| 国产mv日韩mv欧美| 67194成人在线观看| 中文字幕亚洲成人| 热久久国产精品| 色婷婷亚洲一区二区三区| 精品久久久久99| 亚洲第一成人在线| av不卡免费在线观看| 日韩欧美一区二区视频| 一区二区三区日本| 国产suv精品一区二区三区| 91精品国产日韩91久久久久久| 成人免费在线播放视频| 精品制服美女丁香| 制服丝袜成人动漫| 一区二区在线观看免费视频播放| 国产精品一二三四| 日韩免费看的电影| 日韩综合一区二区| 欧美午夜在线一二页| 国产精品伦理在线| 国产精品资源网| 日韩女优视频免费观看| 日本少妇一区二区| 欧美日本一区二区| 亚洲综合偷拍欧美一区色| 处破女av一区二区| 亚洲国产精品二十页| 激情综合五月天| 欧美大黄免费观看| 久久99精品国产| 欧美不卡一区二区| 激情六月婷婷综合| 2023国产精品视频| 国产精品自在欧美一区| 国产亚洲综合性久久久影院| 国产一区二区在线看| 久久一二三国产| 国产成人免费网站| 欧美国产国产综合| caoporn国产精品| 亚洲精品成人精品456| 91美女片黄在线观看91美女| 色综合久久久久| 制服丝袜中文字幕亚洲| 秋霞影院一区二区| 26uuu精品一区二区三区四区在线| 久久电影国产免费久久电影| 欧美一区日本一区韩国一区| 免费成人在线播放| 久久先锋影音av鲁色资源网| 国产a视频精品免费观看| 国产精品久久久久久久久动漫 | 欧美精品乱码久久久久久按摩| 亚洲一卡二卡三卡四卡无卡久久| 日本久久一区二区| 亚洲精品视频观看| 欧美日韩国产一区| 狠狠v欧美v日韩v亚洲ⅴ| 国产午夜久久久久| 欧美天天综合网| 久久国产欧美日韩精品| 久久久天堂av| 色域天天综合网| 男男视频亚洲欧美| 国产精品久久久久久久久快鸭| 色婷婷综合久久久久中文| 美女视频黄频大全不卡视频在线播放| 欧美一区在线视频| 国产 日韩 欧美大片| 亚洲精品视频一区| 久久久美女毛片| 欧美在线观看一区二区| 国内精品久久久久影院色| 亚洲国产成人午夜在线一区| 欧美色图免费看| 国产不卡在线播放| 日韩主播视频在线| 中文字幕一区二区在线播放| 5858s免费视频成人| 成人黄色a**站在线观看| 亚洲1区2区3区4区| 国产精品午夜在线| 欧美刺激脚交jootjob| 91国偷自产一区二区三区成为亚洲经典 | 午夜电影网亚洲视频| 国产亚洲综合在线| 91精品欧美一区二区三区综合在| 精品一区二区三区不卡| 亚洲美女在线一区| 国产精品国产三级国产aⅴ中文| 日韩视频免费观看高清完整版在线观看 | 欧美裸体bbwbbwbbw| 91亚洲精品乱码久久久久久蜜桃| 蜜臀久久久99精品久久久久久| 一区二区欧美在线观看| 中文字幕精品一区二区精品绿巨人 | 色婷婷精品久久二区二区蜜臂av| 九色|91porny| 蜜桃av噜噜一区| 亚洲成av人片www| 亚洲精品欧美专区| 国产精品九色蝌蚪自拍| 欧美国产丝袜视频| 国产亚洲精品7777| 久久亚洲精品小早川怜子| 欧美不卡激情三级在线观看| 欧美日韩一级二级| 欧美视频在线播放| 欧美伊人精品成人久久综合97| 91视频com| 日本乱人伦一区| 在线亚洲一区观看| 欧美色大人视频| 欧美精品乱码久久久久久按摩| 欧美日韩一区中文字幕| 欧美日韩亚洲国产综合| 欧美久久婷婷综合色| 欧美精品一卡两卡| 欧美刺激午夜性久久久久久久 | 精品久久国产老人久久综合| 日韩一区二区在线观看| 日韩欧美中文一区| 欧美精品一区二| 国产精品网站在线观看| 中文字幕在线观看不卡视频| 亚洲精选视频在线| 日韩中文字幕麻豆| 国产一区二区三区电影在线观看| 国产美女在线精品| 91毛片在线观看| 欧美午夜精品一区| 日韩视频国产视频| 久久夜色精品国产噜噜av| 国产精品视频你懂的| 亚洲精品视频免费看| 蜜桃传媒麻豆第一区在线观看| 国产一区二区不卡在线| 一本大道久久a久久综合| 91精品久久久久久久久99蜜臂| 久久夜色精品一区| 一区二区欧美国产| 久久成人久久爱| 一本到不卡精品视频在线观看| 3d成人h动漫网站入口| 日本一区二区高清| 午夜精品视频在线观看| 国产精品一区在线| 在线观看国产91| 久久精品视频免费| 一区av在线播放| 国产成人综合视频| 337p亚洲精品色噜噜狠狠| 国产精品素人一区二区| 丝袜亚洲另类丝袜在线| 成人精品国产福利| 欧美一区二区成人| 亚洲激情自拍视频| 懂色av一区二区三区免费观看| 精品1区2区3区| 亚洲视频一二区| 粉嫩久久99精品久久久久久夜| 这里只有精品电影|