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

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

?? public.cpp

?? 一個C語言實現(xiàn)的壓縮解壓的工具代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
}

void LZARI_Output(int bit)  /* Output 1 bit, followed by its complements */
{
	LZARI_PutBit(bit);
	for ( ; shifts > 0; shifts--) 
		LZARI_PutBit(! bit);
}

void LZARI_EncodeChar(int ch)
{
	int  sym;
	unsigned long int  range;

	sym = char_to_sym[ch];
	range = high - low;
	high = low + (range * sym_cum[sym - 1]) / sym_cum[0];
	low +=       (range * sym_cum[sym    ]) / sym_cum[0];
	for ( ; ; ) 
	{
		if (high <= Q2) 
			LZARI_Output(0);
		else if (low >= Q2) 
		{
			LZARI_Output(1);  
			low -= Q2;  
			high -= Q2;
		} 
		else if (low >= Q1 && high <= Q3) 
		{
			shifts++;  
			low -= Q1;  
			high -= Q1;
		} 
		else 
			break;
		low += low;
		high += high;
	}
	LZARI_UpdateModel(sym);
}

void LZARI_EncodePosition(int position)
{
	unsigned long int  range;

	range = high - low;
	high = low + (range * position_cum[position    ]) / position_cum[0];
	low +=       (range * position_cum[position + 1]) / position_cum[0];
	for ( ; ; ) 
	{
		if (high <= Q2) 
			LZARI_Output(0);
		else if (low >= Q2) 
		{
			LZARI_Output(1);  
			low -= Q2;  
			high -= Q2;
		} 
		else if (low >= Q1 && high <= Q3) 
		{
			shifts++;  
			low -= Q1;  
			high -= Q1;
		} 
		else 
			break;
		low += low;
		high += high;
	}
}

void LZARI_EncodeEnd(void)
{
	shifts++;
	if (low < Q1) 
		LZARI_Output(0);  
	else 
		LZARI_Output(1);
	LZARI_FlushBitBuffer();  /* flush bits remaining in buffer */
}

int LZARI_BinarySearchSym(unsigned int x)
	/* 1      if x >= sym_cum[1],
	   N_CHAR if sym_cum[N_CHAR] > x,
	   i such that sym_cum[i - 1] > x >= sym_cum[i] otherwise */
{
	int i, j, k;
	
	i = 1;  j = N_CHAR;
	while (i < j) 
	{
		k = (i + j) / 2;
		if (sym_cum[k] > x) i = k + 1;  else j = k;
	}
	return i;
}

int LZARI_BinarySearchPos(unsigned int x)
	/* 0 if x >= position_cum[1],
	   N - 1 if position_cum[N] > x,
	   i such that position_cum[i] > x >= position_cum[i + 1] otherwise */
{
	int i, j, k;
	
	i = 1;  j = N;
	while (i < j)
	{
		k = (i + j) / 2;
		if (position_cum[k] > x) i = k + 1;  else j = k;
	}
	return i - 1;
}

void LZARI_StartDecode(void)
{
	int i;

	for (i = 0; i < M + 2; i++)
		value = 2 * value + LZARI_GetBit();
}

int LZARI_DecodeChar(void)
{
	int	 sym, ch;
	unsigned long int  range;
	
	range = high - low;
	sym = LZARI_BinarySearchSym((unsigned int)
		(((value - low + 1) * sym_cum[0] - 1) / range));
	high = low + (range * sym_cum[sym - 1]) / sym_cum[0];
	low +=       (range * sym_cum[sym    ]) / sym_cum[0];
	for ( ; ; ) {
		if (low >= Q2) {
			value -= Q2;  low -= Q2;  high -= Q2;
		} else if (low >= Q1 && high <= Q3) {
			value -= Q1;  low -= Q1;  high -= Q1;
		} else if (high > Q2) break;
		low += low;  high += high;
		value = 2 * value + LZARI_GetBit();
	}
	ch = sym_to_char[sym];
	LZARI_UpdateModel(sym);
	return ch;
}

int LZARI_DecodePosition(void)
{
	int position;
	unsigned long int  range;
	
	range = high - low;
	position = LZARI_BinarySearchPos((unsigned int)
		(((value - low + 1) * position_cum[0] - 1) / range));
	high = low + (range * position_cum[position    ]) / position_cum[0];
	low +=       (range * position_cum[position + 1]) / position_cum[0];
	for ( ; ; ) {
		if (low >= Q2) {
			value -= Q2;  low -= Q2;  high -= Q2;
		} else if (low >= Q1 && high <= Q3) {
			value -= Q1;  low -= Q1;  high -= Q1;
		} else if (high > Q2) break;
		low += low;  high += high;
		value = 2 * value + LZARI_GetBit();
	}
	return position;
}

/********** Encode and Decode **********/

void LZARI_Encode(void)
{
	int  i, c, len, r, s, last_match_length;
	unsigned char cSwap;

	//fseek(infile, 0L, SEEK_END);
	textsize = gui_InSize;//ftell(infile);
#if 0
	if (fwrite(&textsize, sizeof textsize, 1, outfile) < 1)
		LZARI_Error("Write Error");  /* output size of text */
#else
	//LZARI_putc( textsize, gp_OutBuff );
	cSwap = textsize & 0xff;
	gp_OutBuff[gui_ObjIndex++] = cSwap;
	cSwap = ( textsize >> 8 ) & 0xff;
	gp_OutBuff[gui_ObjIndex++] = cSwap;
	cSwap = ( textsize >> 16 ) & 0xff;
	gp_OutBuff[gui_ObjIndex++] = cSwap;
	cSwap = ( textsize >> 24 ) & 0xff;
	gp_OutBuff[gui_ObjIndex++] = cSwap;
#endif
	codesize += sizeof textsize;
	if (textsize == 0) return;
	gui_SrcIndex = 0;//rewind(infile);
	textsize = 0;

	LZARI_StartModel(); 
	LZARI_InitTree();
	s = 0;  r = N - F;
	for (i = s; i < r; i++) 
		text_buf[i] = ' ';

	for (len = 0; len < F && (c = LZARI_getc(gp_InBuff)) != EOF; len++) 
		text_buf[r + len] = c;

	textsize = len;
	for (i = 1; i <= F; i++) 
		LZARI_InsertNode(r - i);
	
	LZARI_InsertNode(r);
	
	do {
		if (match_length > len) match_length = len;
		if (match_length <= THRESHOLD) 
		{
			match_length = 1;  
			LZARI_EncodeChar(text_buf[r]);
		} 
		else
		{
			LZARI_EncodeChar(255 - THRESHOLD + match_length);
			LZARI_EncodePosition(match_position - 1);
		}
		last_match_length = match_length;

		for (i = 0; i < last_match_length && (c = LZARI_getc(gp_InBuff)) != EOF; i++)
		{
			LZARI_DeleteNode(s);
			text_buf[s] = c;
			if (s < F - 1) 
				text_buf[s + N] = c;
			s = (s + 1) & (N - 1);
			r = (r + 1) & (N - 1);
			LZARI_InsertNode(r);
		}

		if ((textsize += i) > printcount) 
		{
#ifdef _OUTPUT_STATUS
			printf("%12ld\r", textsize);
#endif	
			printcount += 1024;
		}
		while (i++ < last_match_length) 
		{
			LZARI_DeleteNode(s);
			s = (s + 1) & (N - 1);
			r = (r + 1) & (N - 1);
			if (--len) 
				LZARI_InsertNode(r);
		}
	} while (len > 0);
	
	LZARI_EncodeEnd();

#ifdef _OUTPUT_STATUS	
	printf("In : %lu bytes\n", textsize);
	printf("Out: %lu bytes\n", codesize);
	printf("Out/In: %.3f\n", (double)codesize / textsize);
#endif
}

void LZARI_Decode(void)
{
	int  i, j, k, r, c;
	unsigned long int  count;
#if 0
	if ( fread(&textsize, sizeof textsize, 1, infile ) < 1 )
		LZARI_Error("Read Error");  /* read size of text */
#else
	textsize = c = gp_InBuff[0] | gp_InBuff[1] << 8 | gp_InBuff[2] << 16 | gp_InBuff[3] << 24;

	gui_SrcIndex += 4;

	if( c < 1 )
		return;
#endif
	
	if (textsize == 0) 
		return;
	
	LZARI_StartDecode();
	LZARI_StartModel();
	
	for (i = 0; i < N - F; i++) text_buf[i] = ' ';
	r = N - F;
	for (count = 0; count < textsize; ) 
	{
		c = LZARI_DecodeChar();
		if (c < 256) 
		{
			LZARI_putc(c, gp_OutBuff);
			text_buf[r++] = c;
			r &= (N - 1);
			count++;
		}
		else
		{
			i = (r - LZARI_DecodePosition() - 1) & (N - 1);
			j = c - 255 + THRESHOLD;
			for (k = 0; k < j; k++) 
			{
				c = text_buf[(i + k) & (N - 1)];

				LZARI_putc(c, gp_OutBuff);

				text_buf[r++] = c;
				r &= (N - 1);
				count++;
			}
		}
		if (count > printcount) 
		{
#ifdef _OUTPUT_STATUS
			printf("%12lu\r", count);
#endif			
			printcount += 1024;
		}
	}

#ifdef _OUTPUT_STATUS
	printf("%12lu\n", count);
#endif
}

void LZARI_Compress( unsigned char* pInBuffer,			// 入口緩沖指針
					 unsigned int ui_InSize,			// 入口文件大小
					 unsigned char* pOutBuffer,			// 出口緩沖指針
					 unsigned int *pi_OutSize			// 出口文件大小
					)
{
	LZARI_LZARI();

	if( pInBuffer && pOutBuffer && ui_InSize && pi_OutSize )
	{
		*pi_OutSize		= 0;
		gui_SrcIndex	= 0;
		gui_ObjIndex	= 0;
		gui_InSize		= ui_InSize;
		gp_InBuff		= pInBuffer;
		gp_OutBuff		= pOutBuffer;
		LZARI_Encode();
		*pi_OutSize		= gui_ObjIndex;
	}
	LZARI_LZARITerm();
}

void LZARI_UnCompress( unsigned char* pInBuffer,			// 入口緩沖指針
					 unsigned int ui_InSize,			// 入口文件大小
					 unsigned char* pOutBuffer,			// 出口緩沖指針
					 unsigned int *pi_OutSize			// 出口文件大小
					)
{
	LZARI_LZARI();
	if( pInBuffer && pOutBuffer && ui_InSize && pi_OutSize )
	{
		gp_InBuff		= pInBuffer;
		gp_OutBuff		= pOutBuffer;
		gui_InSize		= ui_InSize;
		*pi_OutSize		= 0;
		gui_SrcIndex	= 0;
		gui_ObjIndex	= 0;
		LZARI_Decode();
		*pi_OutSize		= gui_ObjIndex;
	}
	LZARI_LZARITerm();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产清纯在线一区二区www| 久久国产婷婷国产香蕉| 日本在线不卡视频| 不卡一区中文字幕| 欧美亚洲综合网| 中文字幕日韩精品一区| 国内久久精品视频| 91精品国产综合久久精品| 亚洲日本一区二区三区| 国产成人8x视频一区二区| 日韩三级电影网址| 亚洲成人免费在线| 91在线看国产| 国产精品久久久久国产精品日日| 三级亚洲高清视频| 欧美在线高清视频| 亚洲乱码一区二区三区在线观看| 丁香另类激情小说| 久久天天做天天爱综合色| 久久99精品久久久久久国产越南| 欧美精品一二三区| 亚洲午夜久久久久| 欧美性猛交一区二区三区精品| 中文字幕精品一区二区精品绿巨人| 国产一区二区在线看| 精品日韩在线观看| 精品一区二区三区免费观看| 777午夜精品免费视频| 亚洲国产你懂的| 欧美特级限制片免费在线观看| 亚洲精品第1页| 91成人看片片| 午夜精品在线看| 欧美日韩一区二区三区视频| 夜夜嗨av一区二区三区| 欧洲av在线精品| 亚洲图片有声小说| 欧美三级中文字| 日本色综合中文字幕| 日韩精品一区二区三区视频播放 | 成人av电影在线网| 国产精品传媒入口麻豆| 97精品久久久午夜一区二区三区| 中文字幕va一区二区三区| 成人av电影在线播放| 伊人色综合久久天天人手人婷| 欧美自拍丝袜亚洲| 日本不卡1234视频| 久久久91精品国产一区二区三区| 成人性生交大合| 亚洲一区二区三区激情| 日韩一区二区三免费高清| 国产呦精品一区二区三区网站 | 欧美日韩国产综合一区二区三区| 轻轻草成人在线| 久久综合99re88久久爱| 成人97人人超碰人人99| 亚洲成人午夜影院| 久久人人97超碰com| 色系网站成人免费| 蜜臀av一区二区在线观看| 欧美极品少妇xxxxⅹ高跟鞋| 日本韩国精品一区二区在线观看| 亚洲超碰精品一区二区| 国产天堂亚洲国产碰碰| 欧美视频在线不卡| 国产成人夜色高潮福利影视| 一区二区日韩电影| 久久午夜电影网| 欧美日韩激情一区| 成人午夜碰碰视频| 蜜臀av一区二区| 亚洲另类色综合网站| 欧美精品一区二区不卡 | 精品美女被调教视频大全网站| 成人性生交大片免费看中文 | 欧美一卡二卡在线| gogo大胆日本视频一区| 免费欧美高清视频| 一区二区三区蜜桃| 久久久久久久久久久电影| 欧美日韩一级大片网址| 成人激情免费电影网址| 久久精品国产99久久6| 亚洲精品国产成人久久av盗摄| 久久免费偷拍视频| 日韩视频一区二区在线观看| 91豆麻精品91久久久久久| 岛国一区二区三区| 国产伦理精品不卡| 日本不卡视频一二三区| 夜夜嗨av一区二区三区中文字幕| 国产欧美日韩卡一| 久久久国产午夜精品| 日韩一区二区精品葵司在线| 欧美性色综合网| 91激情在线视频| 成人av在线网| 成人天堂资源www在线| 久久99国产乱子伦精品免费| 天堂久久一区二区三区| 一区二区三区不卡视频在线观看 | 成人欧美一区二区三区| 亚洲国产精品精华液2区45| 精品国内二区三区| 精品国产电影一区二区| 在线成人av影院| 欧美高清dvd| 制服丝袜成人动漫| 欧美群妇大交群的观看方式| 欧美日韩精品一区二区天天拍小说| 一本一道波多野结衣一区二区| 99精品热视频| 91麻豆.com| 在线精品观看国产| 在线看国产一区| 欧美久久久久久久久中文字幕| 欧美怡红院视频| 在线成人小视频| 欧美一区二区播放| 久久网这里都是精品| 国产免费久久精品| 亚洲欧美另类图片小说| 亚洲免费在线观看| 亚洲国产欧美一区二区三区丁香婷| 亚洲综合色噜噜狠狠| 五月天激情综合网| 美女一区二区在线观看| 国产寡妇亲子伦一区二区| 成人亚洲一区二区一| 日本精品一区二区三区高清 | 欧美日韩视频不卡| 日韩午夜激情免费电影| 精品三级在线观看| 国产精品免费aⅴ片在线观看| 日韩一区在线免费观看| 亚洲.国产.中文慕字在线| 免费观看成人av| 成人免费视频国产在线观看| 在线观看亚洲一区| 日韩精品一区二| 国产精品久久久久久久久图文区| 亚洲色图欧美在线| 久久国产精品无码网站| 成人综合在线观看| 欧美女孩性生活视频| 欧美激情一区在线观看| 一区二区三区在线免费视频| 久久99国产精品免费网站| a级精品国产片在线观看| 欧美色精品天天在线观看视频| 2022国产精品视频| 亚洲伊人色欲综合网| 国产在线播精品第三| 在线精品视频一区二区| 久久久国际精品| 亚洲成av人片一区二区三区| 国产精品456| 欧美乱熟臀69xxxxxx| 国产精品久久久久影视| 蜜桃视频一区二区三区在线观看| www.色精品| 欧美videos中文字幕| 亚洲一区二区三区在线看| 国产精品夜夜嗨| 91精品国产一区二区三区| 最好看的中文字幕久久| 国产精品亚洲人在线观看| 91麻豆精品国产91久久久更新时间| 国产精品毛片a∨一区二区三区| 日本特黄久久久高潮| 欧洲av在线精品| 中文字幕视频一区| 懂色av一区二区夜夜嗨| 日韩女优电影在线观看| 午夜视频一区二区三区| 一本一道久久a久久精品| 国产精品美日韩| 国产美女一区二区| 日韩视频一区在线观看| 日韩和的一区二区| 欧美视频在线一区| 一区二区三区四区在线免费观看 | 成人丝袜18视频在线观看| 日韩亚洲欧美一区二区三区| 亚洲福利一区二区三区| 欧美性受xxxx黑人xyx| 夜夜精品浪潮av一区二区三区| 99视频在线精品| 国产精品麻豆久久久| 不卡区在线中文字幕| 国产精品午夜电影| 国产999精品久久久久久| 国产日韩高清在线| 国产成人在线视频网址| 日本一区二区三区久久久久久久久不 | 不卡电影一区二区三区| 国产精品久久久久久久第一福利| 国产成人午夜片在线观看高清观看| 精品国产伦一区二区三区观看方式|