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

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

?? lzwcode.cpp

?? 用VC++實(shí)現(xiàn)LZW算法
?? CPP
字號:
#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
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
制服丝袜亚洲精品中文字幕| 中文字幕免费观看一区| 国产精选一区二区三区| 伊人性伊人情综合网| 精品国产乱码久久| 欧美日韩一区三区| 9久草视频在线视频精品| 久久精品99国产精品日本| 亚洲精品中文字幕在线观看| 久久久久久久av麻豆果冻| 欧美精品vⅰdeose4hd| 99精品欧美一区| 国产福利一区二区三区视频| 男人的j进女人的j一区| 一区二区三区波多野结衣在线观看 | 中文字幕一区二区三区精华液| 欧美精品一二三| 一本一本久久a久久精品综合麻豆| 韩国一区二区三区| 秋霞电影一区二区| 亚洲成人综合视频| 亚洲自拍偷拍欧美| 亚洲欧美另类在线| 国产精品美女视频| 国产午夜亚洲精品不卡| 久久久久久毛片| 精品捆绑美女sm三区| 91精品国产综合久久福利| 欧美午夜精品一区二区三区| 色综合久久天天综合网| 99热精品国产| av午夜一区麻豆| 国产**成人网毛片九色| 国产不卡一区视频| 国产成人8x视频一区二区| 国产一区二区在线影院| 九九**精品视频免费播放| 九九九久久久精品| 国产在线精品一区二区夜色| 精品一区二区三区欧美| 国产综合久久久久影院| 国产专区欧美精品| 国产美女娇喘av呻吟久久| 激情综合一区二区三区| 国产在线国偷精品免费看| 韩国欧美国产1区| 国产酒店精品激情| 丁香天五香天堂综合| 成人黄色免费短视频| 91网址在线看| 欧美午夜精品久久久久久超碰 | 亚洲欧美在线视频观看| 亚洲欧美日韩在线| 依依成人综合视频| 无码av免费一区二区三区试看 | 日韩一区二区精品葵司在线 | 欧美体内she精高潮| 欧美日韩视频第一区| 欧美巨大另类极品videosbest | 最新日韩在线视频| 亚洲精品国久久99热| 亚洲一级二级在线| 蜜臀av性久久久久av蜜臀妖精| 寂寞少妇一区二区三区| 国产成人av在线影院| 色综合夜色一区| 欧美三级在线播放| 日韩欧美国产一区在线观看| 久久精品亚洲精品国产欧美 | 日产国产欧美视频一区精品| 激情综合网av| av一本久道久久综合久久鬼色| 欧美在线短视频| 日韩一区二区在线观看视频播放| 久久久久久久性| 中文字幕一区二区三区色视频| 亚洲午夜精品在线| 久久精品国产**网站演员| 成人av电影在线观看| 欧美日韩国产不卡| 国产欧美精品一区| 亚洲国产三级在线| 国产一区中文字幕| 欧美系列日韩一区| 国产亚洲一本大道中文在线| 一区二区三区产品免费精品久久75| 日韩av成人高清| 91同城在线观看| 欧美成人三级在线| 亚洲女爱视频在线| 国模冰冰炮一区二区| 在线观看精品一区| 国产日韩欧美不卡在线| 日韩精品一区第一页| 国产+成+人+亚洲欧洲自线| 欧美剧情片在线观看| 欧美国产成人在线| 美女视频一区在线观看| 色偷偷久久一区二区三区| 337p粉嫩大胆色噜噜噜噜亚洲| 一区二区三区在线免费| 国产一区二区三区高清播放| 欧美裸体一区二区三区| 国产精品色婷婷久久58| 极品少妇xxxx精品少妇偷拍| 欧美日韩在线精品一区二区三区激情 | 日韩精品午夜视频| 99热在这里有精品免费| 久久久一区二区三区捆绑**| 午夜欧美大尺度福利影院在线看| 成人高清免费观看| 久久综合成人精品亚洲另类欧美| 天堂资源在线中文精品| 色女孩综合影院| 国产精品久久一级| 国产成人精品免费| 久久综合丝袜日本网| 毛片基地黄久久久久久天堂| 色琪琪一区二区三区亚洲区| 国产精品视频观看| 国产精品一级黄| 久久综合色鬼综合色| 老司机精品视频线观看86| 91精品国产美女浴室洗澡无遮挡| 亚洲香蕉伊在人在线观| 91久久精品网| 亚洲欧美日韩一区二区| 91免费视频观看| 亚洲三级在线免费观看| 91网站在线播放| 综合激情成人伊人| 色综合天天天天做夜夜夜夜做| 国产精品久久久久久久久果冻传媒| 国产高清不卡二三区| 久久精品视频在线看| 国产乱码精品一区二区三区五月婷 | 亚洲一区在线看| 在线观看一区二区视频| 一区二区在线观看免费| 色狠狠综合天天综合综合| 亚洲视频电影在线| 欧洲另类一二三四区| 亚洲自拍偷拍欧美| 欧美日韩免费视频| 亚洲h在线观看| 日韩视频在线你懂得| 看电视剧不卡顿的网站| 精品国产免费一区二区三区四区 | 国产在线精品一区二区不卡了| 日韩精品专区在线影院观看| 久久精品国产精品青草| 久久亚洲精华国产精华液| 成人黄页毛片网站| 中文字幕一区二区三区四区 | 2024国产精品视频| 国产成人av福利| 亚洲人成精品久久久久| 在线免费观看一区| 日日夜夜免费精品| www激情久久| 99精品热视频| 天堂久久久久va久久久久| 精品国产亚洲在线| av亚洲精华国产精华精| 天堂久久久久va久久久久| www成人在线观看| 91在线观看视频| 日韩av一级电影| 国产精品麻豆视频| 精品视频在线看| 国产精品一卡二卡在线观看| 亚洲另类春色国产| 日韩午夜激情av| www.亚洲人| 日韩成人一级大片| 国产精品美女久久久久aⅴ| 欧美午夜在线观看| 国产一区91精品张津瑜| 亚洲色欲色欲www在线观看| 91精品国产日韩91久久久久久| 国产精品一区二区三区四区| 亚洲一区中文日韩| 久久精品一区二区三区av| 欧美日韩一区二区欧美激情| 国产精品资源站在线| 亚洲自拍都市欧美小说| 欧美精品一区二区久久久| 欧美性猛交xxxx乱大交退制版| 精品一区二区免费视频| 一区二区三区在线视频免费| 精品av久久707| 欧美日韩视频在线一区二区| 成人免费看视频| 免费观看在线综合| 亚洲精品成a人| 国产精品污网站| 精品裸体舞一区二区三区| 在线欧美小视频| av亚洲精华国产精华| 激情综合五月婷婷|