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

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

?? 數據壓縮dlg.cpp

?? 自己做的作業(自適應霍夫曼解壓縮) 完成功能解壓縮文件!方法:自適應霍夫曼編碼(8bit編碼)(有GUI界面)
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
	m_Time.SetWindowText(gmsg);
	sprintf(gmsg,"");
	m_Ratio.SetWindowText(gmsg);
	
	//設置存儲空間
    BYTE *output,*outputmemp;
	outputmemp = (BYTE *)GlobalAlloc(GMEM_MOVEABLE,length);
    output = (BYTE *)GlobalLock(outputmemp);
	//創建Huffman樹,并初始化
	TREE Tree;
	InitializeTree(&Tree);
	
	outlength = 0;//輸出壓縮比特長度
	for(unsigned long i=0;i<length;i++)
	{//逐個字符進行壓縮
		jc = i;
		EncodeSymbol(&Tree,buf[i],output);//對字符進行編碼,新字符加入樹
		UpdateWeight(&Tree,buf[i]);//更新碼重,并調整樹
	}

	CString savename = CurrentFileName + ".lcg";
    CurrentFileName = FileName + ".lcg";
	FileHeader *fileheader = new FileHeader;
	fileheader->namelength = FileName.GetLength()+1;
	
	fileheader->oldlength = length;
	fileheader->newlength = outlength;
	//寫文件頭信息(被壓縮文件名,壓縮前長度,壓縮后長度(比特))
	CFile savefile;
	savefile.Open(savename,CFile::modeCreate | CFile::modeReadWrite  | CFile::shareDenyNone);
	savefile.WriteHuge(fileheader,sizeof(FileHeader));
	savefile.Close();
	savefile.Open(savename,CFile::modeReadWrite  | CFile::shareDenyNone);
	savefile.Seek(sizeof(FileHeader),CFile::begin);
	savefile.WriteHuge(FileName,fileheader->namelength);
	savefile.Close();
	//寫文件壓縮數據
	savefile.Open(savename,CFile::modeReadWrite  | CFile::shareDenyNone);
	savefile.Seek(sizeof(FileHeader) + fileheader->namelength,CFile::begin);
	savefile.WriteHuge(output,(outlength+7)/8);
	savefile.Close();
	//釋放內存
	delete(fileheader);
	GlobalUnlock(filebuf);
	GlobalFree(filememp);
	GlobalUnlock(output);
	GlobalFree(outputmemp);
	//壓縮后文件長度
	sprintf(gmsg,"%d",outlength/8/1024);
	m_FileLength2.SetWindowText(gmsg);
    //計算壓縮比
	sprintf(gmsg,"%2.2f",(double)(outlength)/(length*8)*100);
	m_Ratio.SetWindowText(gmsg);
	//設置工作狀態
	m_ProgBar.SetPos(100);
	workflag = false;
}
void CMyDlg::Decode()
{//解壓
	char gmsg[300];
	BYTE tmp[300];
	workflag = true;
	timenum = 0;
	SetTimer(1,100,NULL);
	outlength = 0;
	CurrentFileName = FileList[0];
	//讀入文件
	CFile openfile;
	openfile.Open(CurrentFileName,CFile::modeRead | CFile::shareDenyNone);
	length = openfile.GetLength();
	BYTE *filebuf,*filememp;
	filememp = (BYTE *)GlobalAlloc(GMEM_MOVEABLE,length);
    filebuf = (BYTE *)GlobalLock(filememp);
	length = openfile.ReadHuge(filebuf,length);
	openfile.Close();

    FileHeader *fileheader = (FileHeader *)filebuf;
    memcpy(tmp,&filebuf[sizeof(FileHeader)],fileheader->namelength);
	
	BYTE *buf = &filebuf[sizeof(FileHeader) + fileheader->namelength];
	
	sprintf(gmsg,"解壓前長度:");
	m_L1.SetWindowText(gmsg);
	sprintf(gmsg,"解壓后長度:");
	m_L2.SetWindowText(gmsg);
	sprintf(gmsg,"解壓比:");
	m_R1.SetWindowText(gmsg);
	sprintf(gmsg,"解壓時間:");
	m_T1.SetWindowText(gmsg);
	sprintf(gmsg,"%d",length/1024);
	m_FileLength.SetWindowText(gmsg);
	sprintf(gmsg,"%d",fileheader->oldlength/1024);
	m_FileLength2.SetWindowText(gmsg);
    sprintf(gmsg,"%02d時%02d分%02d秒",timenum/36000,timenum/600,timenum/10);
	m_Time.SetWindowText(gmsg);
	sprintf(gmsg,"");
	m_Ratio.SetWindowText(gmsg);
	
    BYTE *output,*outputmemp;
	outputmemp = (BYTE *)GlobalAlloc(GMEM_MOVEABLE,length*5);
    output = (BYTE *)GlobalLock(outputmemp);
	TREE Tree;
	InitializeTree(&Tree);
	outlength = 0;
	BYTE ch = 0;
	unsigned long j = 0;
	for(;outlength<fileheader->newlength;)
	{
		jc = outlength/8;
		output[j++] = ch = DecodeSymbol(&Tree,buf);
		UpdateWeight(&Tree,ch);
	}
	CString str,savename ;
	str.Format("%s",tmp);
	savename = "LCG_" + str;
	CurrentFileName = savename;
	CFile savefile;
	savefile.Open(savename,CFile::modeCreate | CFile::modeReadWrite  | CFile::shareDenyNone);
	savefile.WriteHuge(output,j);
	savefile.Close();
	GlobalUnlock(filebuf);
	GlobalFree(filememp);
	GlobalUnlock(output);
	GlobalFree(outputmemp);
	
	sprintf(gmsg,"%2.2f",(double)(outlength)/(j*8)*100);
	m_Ratio.SetWindowText(gmsg);
	m_ProgBar.SetPos(100);
	workflag = false;
	
}
void CMyDlg::InitializeTree(TREE *tree)
{
	//初始化Huffman樹,設置根節點 = NYT
	tree->nodes[ROOT_NODE].child = NYT;
	tree->nodes[ROOT_NODE].child_is_leaf = true;
	tree->nodes[ROOT_NODE].weight = 0;
	tree->nodes[ROOT_NODE].parent = -1;

	tree->leaf[NYT] = ROOT_NODE;
	for(int i = 0;i < NYT; i++)
	{//每個字符所在節點位置,初值 -1,當發現此字符節點位置 = -1時,說明是新字符
		tree->leaf[i] = -1;
	}
}
void CMyDlg::EncodeSymbol(TREE *tree, BYTE ch, BYTE *output)
{//對字符進行編碼,新字符加入樹
	long int current_node;
	current_node = tree->leaf[ch];
	BYTE tabletmp[8] = {0x00,0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe};//兩個臨時碼表,用于計算
	BYTE tabletmp2[8] = {0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01};
	int x,y,n;
	char chartmp[256],tmp;//臨時記錄字符編碼,然后**倒序**輸出
	x = outlength/8;      //獲得輸出位置
	y = outlength%8;      //獲得非整字節剩余比特數
	if(current_node == -1)
	{//字符是第一次出現,把位置指到NYT所在節點位置
		current_node = tree->leaf[NYT];
	}
	n = 0;//記錄字符編碼長度
	while(current_node !=ROOT_NODE)
	{//從葉節點向父節點查詢,直到根節點結束
		chartmp[n++] = (current_node%2);
	//如果節點是偶數,說明在左邊,用0編碼
	//如果節點是奇數,說明在右邊,用1編碼
		current_node = tree->nodes[current_node].parent;
	}
	if(y == 0)         //如果是整字節
		tmp = 0;
	else
		tmp = output[x];//否則,提取最后一字節信息部分
	for(n--;n>=0;n--)
	{//倒序輸出編碼
		if(chartmp[n])//在相應的位置上加 1
			tmp += tabletmp2[y++];
		else
			y++;
		if(y == 8)
		{//當tmp裝滿,輸出到output
			output[x++] = tmp;
			tmp = 0;
			y = 0;
		}
	}
	output[x] = tmp;//輸出剩余比特
	outlength = x * 8 + y;//記錄編碼長度
	if(tree->leaf[ch] == -1)
	{//字符是第一次出現,輸出源碼,8比特
		x = outlength/8;
		y = outlength%8;
		if(y == 0)
		{//整字節,直接裝入
			output[x] = ch;
		}
		else
		{//非整字節,需移位
			output[x] = (output[x]&tabletmp[y]) + (ch>>y);
			output[x + 1] = (ch<<(8-y));
		}
		outlength += 8;//記錄編碼長度
		add_new_node(tree,ch);//把新字符裝到Huffman樹中
	}
}
int CMyDlg::DecodeSymbol(TREE *tree, BYTE *intput)
{//對壓縮編碼解碼
	long int current_node;
	int ch;
	int x,y;
	BYTE tabletmp2[8] = {0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01};
	WORD tmp;
	current_node = ROOT_NODE ;
	while(!tree->nodes[current_node].child_is_leaf)
	{//從根節點向子節點查詢,直到葉節點結束
		current_node = tree->nodes[current_node].child - 1;
		x = outlength/8;
		y = outlength%8;
		if((intput[x] & tabletmp2[y]) == 0)//根據編碼判斷向左走,還是向右走
			current_node += 1;//如果是1向右走,0向左走
		outlength++;//壓縮編碼計數
	}
	ch = tree->nodes[current_node].child;//獲得葉節點字符
	if(ch == NYT)
	{//如果字符是NYT,輸出后面8比特源碼
		x = outlength/8;
		y = outlength%8;
		if(y == 0)
			ch = intput[x];
		else
		{
		    tmp = (intput[x]<<8) +intput[x+1];
			ch  = (tmp>>(8-y))&0xff;
		}
		outlength += 8;//壓縮編碼計數
		add_new_node(tree,ch);//把新字符裝到Huffman樹中
	}
	return(ch);//返回解碼字符
}
void CMyDlg::UpdateWeight(TREE *tree, WORD ch)
{//更新碼重,并調整樹
	long int current_node;
	long int new_node;
	current_node = tree->leaf[ch];
	while(current_node != -1)
	{//從當前節點向上比較,
		for(new_node = current_node; new_node > ROOT_NODE ;new_node--)
		{//從當前節點到根節點
			if(tree->nodes[new_node -1 ].weight > tree->nodes[current_node].weight)
				break;//如果有比它權重大的,跳出
		}
		if(tree->nodes[current_node].parent != new_node && current_node != new_node)
		{//如果比它大的節點的前一個節點不是他的父親,也不是他自己,交換節點
			swap_nodes(tree,current_node,new_node);//交換節點
			current_node = new_node;
		}
		tree->nodes[current_node].weight++;//當前節點權重加1
		current_node = tree->nodes[current_node].parent;//繼續向父親查詢
	}
}
void CMyDlg::swap_nodes(TREE *tree, long int current_node, long int new_node)
{//交換節點
	CMyDlg::tree::node temp;
	if(tree->nodes[current_node].child_is_leaf)//是葉節點,更新孩子(字符)的位置
		tree->leaf[tree->nodes[current_node].child] = new_node;
	else
	{//不是葉節點,更新兩個孩子的父節點位置
		tree->nodes[tree->nodes[current_node].child].parent = new_node;
		tree->nodes[tree->nodes[current_node].child - 1].parent = new_node;
	}
	if(tree->nodes[new_node].child_is_leaf)
		tree->leaf[tree->nodes[new_node].child] = current_node;
	else
	{
		tree->nodes[tree->nodes[new_node].child].parent = current_node;
		tree->nodes[tree->nodes[new_node].child - 1].parent = current_node;
	}
	temp = tree->nodes[current_node];
	tree->nodes[current_node] = tree->nodes[new_node];
	tree->nodes[current_node].parent = temp.parent;
	temp.parent = tree->nodes[new_node].parent;
	tree->nodes[new_node] = temp;
}
void CMyDlg::add_new_node(TREE *tree, WORD ch)
{//添加新字符到Huffman樹
	long int old_node;//原節點 
    long int new_node;//新字符節點
	long int NYT_node;//
	old_node = tree->leaf[NYT];
	new_node = tree->leaf[NYT] + 1;
	NYT_node = tree->leaf[NYT] + 2;
	
	tree->nodes[old_node].child = new_node + 1;
	tree->nodes[old_node].child_is_leaf = false;

	tree->nodes[new_node].child = ch;
	tree->nodes[new_node].parent = old_node;
	tree->nodes[new_node].child_is_leaf = true;
	tree->nodes[new_node].weight = 0;
	
	tree->nodes[NYT_node].child = NYT;
	tree->nodes[NYT_node].child_is_leaf = true;
	tree->nodes[NYT_node].weight = 0;
	tree->nodes[NYT_node].parent = old_node;
	
	tree->leaf[ch] = new_node;
	tree->leaf[NYT] = NYT_node;
}

void CMyDlg::OnBtnhelp() 
{
   CHelp dlg;
   dlg.DoModal();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美另类变人与禽xxxxx| 国产精品免费免费| 高清不卡一二三区| 亚洲国产精品自拍| 亚洲色图欧美激情| 国产目拍亚洲精品99久久精品| 日韩一区二区视频| 欧美美女bb生活片| 国产精品传媒在线| 亚洲免费观看高清完整版在线 | 欧美日韩一本到| 一本色道久久加勒比精品 | 国产欧美日韩精品a在线观看| 一区二区三区在线播| 亚洲综合一二区| 日韩精品亚洲一区二区三区免费| 亚洲一区二区三区爽爽爽爽爽| 国模娜娜一区二区三区| 韩国精品在线观看| 欧美精品一卡二卡| 一区二区在线免费| 久久精品理论片| 韩国欧美国产1区| 日韩一区二区在线看| 亚洲国产精品麻豆| 色999日韩国产欧美一区二区| 精品视频一区二区不卡| 亚洲另类色综合网站| 成人高清免费观看| 在线一区二区三区做爰视频网站| 国产精品毛片a∨一区二区三区| 国产在线播放一区二区三区| av在线播放成人| 欧美久久久久久久久| 一二三四社区欧美黄| 色欧美片视频在线观看在线视频| 中文字幕一区二区不卡| 日本中文字幕一区| 国产91精品免费| 国产午夜精品一区二区三区视频| 亚洲乱码国产乱码精品精98午夜| 成人国产精品免费观看| 亚洲视频狠狠干| 在线免费视频一区二区| 日本一区二区三级电影在线观看 | xvideos.蜜桃一区二区| 国产精品久久久久桃色tv| 国产不卡在线视频| 国产精品女同互慰在线看| 一本一道波多野结衣一区二区| 亚洲精品成人天堂一二三| 欧美制服丝袜第一页| 亚洲成国产人片在线观看| 成人性视频免费网站| 欧美成人高清电影在线| 亚洲欧洲美洲综合色网| 色菇凉天天综合网| 日本成人在线看| 久久久久国产精品麻豆ai换脸 | 激情综合一区二区三区| 欧美日韩日日摸| 久久99久久久欧美国产| 国产欧美精品一区二区色综合朱莉| 99在线精品免费| 日本一区中文字幕| 欧美极品xxx| 国产精品一级黄| 日韩欧美国产综合| 亚洲一区二区影院| 日韩一二三区视频| eeuss鲁片一区二区三区在线看| 亚洲一区二区三区视频在线| 欧美mv日韩mv亚洲| 一本久道中文字幕精品亚洲嫩| 日本不卡视频在线| 欧美一区二区三区在线看| 一区二区三区免费网站| 日韩欧美一区二区在线视频| 国产东北露脸精品视频| 中文字幕精品一区二区三区精品| 欧美自拍丝袜亚洲| 国产成人啪免费观看软件| 亚洲成人先锋电影| 国产精品视频观看| 日韩一区二区在线播放| 日本黄色一区二区| 国产精品羞羞答答xxdd| 日本伊人精品一区二区三区观看方式| 国产精品久久久久影院老司 | 日韩视频123| 91久久精品午夜一区二区| 国产露脸91国语对白| 日av在线不卡| 亚洲成人激情社区| 亚洲人成在线观看一区二区| 国产日韩高清在线| 久久久美女毛片| 日韩精品资源二区在线| 91麻豆精品国产| 国模娜娜一区二区三区| 蜜臀99久久精品久久久久久软件| 91精品国产综合久久精品| 色成人在线视频| 91玉足脚交白嫩脚丫在线播放| 有坂深雪av一区二区精品| 国产精品久久精品日日| 欧美国产激情二区三区| 国产午夜精品在线观看| 久久人人爽爽爽人久久久| 欧美不卡123| 欧美mv日韩mv| 精品粉嫩超白一线天av| 91丨porny丨国产入口| 成人avav影音| gogogo免费视频观看亚洲一| 成人va在线观看| av电影在线观看完整版一区二区| 国产福利不卡视频| 国产黑丝在线一区二区三区| 国产成人h网站| 懂色av噜噜一区二区三区av| 国产高清成人在线| 国产精品羞羞答答xxdd| 成人禁用看黄a在线| 成人黄页在线观看| 91麻豆蜜桃一区二区三区| 91久久精品日日躁夜夜躁欧美| 在线观看免费亚洲| 宅男噜噜噜66一区二区66| 日韩片之四级片| 精品电影一区二区| 亚洲国产精品ⅴa在线观看| 亚洲日本在线a| 亚洲自拍偷拍欧美| 日本欧美韩国一区三区| 国产主播一区二区三区| 成人综合在线观看| 欧美三级午夜理伦三级中视频| 欧美精品粉嫩高潮一区二区| 日韩免费视频一区二区| 国产精品久久综合| 亚洲一二三四在线| 久久精品免费观看| av一区二区三区在线| 678五月天丁香亚洲综合网| www精品美女久久久tv| **网站欧美大片在线观看| 天堂一区二区在线免费观看| 国产一区二区精品久久99| www.日韩av| 精品久久人人做人人爱| 中文字幕一区二区三区视频| 日韩黄色片在线观看| 国产成人免费视频| 欧美日韩一级大片网址| 久久精品视频网| 亚洲成人av在线电影| 成人性生交大片免费看视频在线 | 欧美日韩一区二区三区四区 | 久久亚洲捆绑美女| 亚洲国产精品久久一线不卡| 国产剧情一区在线| 欧美日韩国产综合视频在线观看| 色88888久久久久久影院按摩| 欧美一级久久久| 亚洲日本一区二区| 国产一区二区免费看| 色素色在线综合| 国产视频一区二区在线观看| 午夜电影网亚洲视频| 免费在线观看不卡| 91视频免费播放| 久久精品视频免费| 视频一区二区三区入口| 91黄色小视频| 国产精品二三区| 国产裸体歌舞团一区二区| 欧美精品v日韩精品v韩国精品v| 国产精品嫩草影院com| 国产一区二区三区免费在线观看 | 久久综合五月天婷婷伊人| 亚洲18影院在线观看| av成人动漫在线观看| 久久久欧美精品sm网站| 免费人成在线不卡| 欧美日韩一级二级| 亚洲精品国产一区二区精华液| 国产激情视频一区二区三区欧美| 欧美一区二区三区的| 五月天一区二区| 欧美日韩国产精选| 亚洲午夜羞羞片| 欧美日韩一级大片网址| 亚洲午夜视频在线观看| 欧美中文字幕久久| 中文字幕日韩精品一区| 国产精品一区二区在线观看网站| 欧美精品一区二区三区在线| 日本va欧美va欧美va精品| 欧美剧情片在线观看|