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

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

?? 哈弗曼數(shù).cpp

?? 哈夫曼樹又稱最優(yōu)二叉樹
?? CPP
字號:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

//Huffman樹的存儲結(jié)構(gòu)
#define n 4					//葉子數(shù)目
#define m 2*n-1					//樹中結(jié)點(diǎn)總數(shù)
typedef struct					//結(jié)點(diǎn)類型
{	float weight;				//權(quán)值,不妨設(shè)權(quán)值均大于零
	int lchild,rchild,parent;	//左右孩子及雙親指針
}HTNode;
typedef HTNode HuffmanTree[m];	//HuffmanTree是向量類型

typedef struct
{	char ch;					//存儲字符
	char bits[n+1];				//存放編碼位串
}CodeNode;
typedef CodeNode HuffmanCode[n];

void InitHuffmanTree(HuffmanTree T);	//初始化Huffman樹
void InputWeight(HuffmanTree T);		//輸入權(quán)值
void SelectMin(HuffmanTree T,int i,int *p1,int *p2);

void main()
{
	
	void CreateHuffmanTree(HuffmanTree T);	//構(gòu)造Huffman樹
	void CharSetHuffmanEncoding(HuffmanTree T,HuffmanCode H);
	HuffmanTree T;
	HuffmanCode H;
	CreateHuffmanTree(T);
	CharSetHuffmanEncoding(T,H);
}

void CreateHuffmanTree(HuffmanTree T)
{ 	//構(gòu)造Huffman樹,T[m-1]為其根結(jié)點(diǎn)
	int i,p1,p2;
	InitHuffmanTree(T);		//將T初始化
	InputWeight(T);			//輸入葉子權(quán)值至T[0..n-1]的weight域
	for(i=n;i<m;i++)		//共進(jìn)行n-1次合并,新結(jié)點(diǎn)依次存于T[i]中
	{	SelectMin(T,i-1,&p1,&p2);
		//在T[0..i-1]中選擇兩個權(quán)最小的根結(jié)點(diǎn),其序號分別為p1和p2
		T[p1].parent=T[p2].parent=i;
		T[i].lchild=p1;		//最小權(quán)的根結(jié)點(diǎn)是新結(jié)點(diǎn)的左孩子
		T[i].rchild=p2;		//次小權(quán)的根結(jié)點(diǎn)是新結(jié)點(diǎn)的右孩子
		T[i].weight=T[p1].weight+T[p2].weight;
	}
}

void InitHuffmanTree(HuffmanTree T)
{	//初始化Huffman樹
	int i;
	for (i=0;i<m;i++)
	{
		T[i].weight=0;
		T[i].lchild=T[i].rchild=T[i].parent=NULL;
	}
}

void InputWeight(HuffmanTree T)
{	//輸入權(quán)值
	int i;
	for (i=0;i<n;i++)
	{
		printf("請輸入第%d個權(quán)值:",i+1);
		scanf("%f",&T[i].weight);
	}
}

void SelectMin(HuffmanTree T,int i,int *p1,int *p2)
{	//在T中選擇兩個權(quán)最小的根結(jié)點(diǎn)
	int j;
	float min1,min2;
	min1=min2=-1;
	for(j=0;j<=i;j++)
		if(T[j].parent==NULL)
		{
			if(T[j].weight<min1||min1==-1)
			{
				if(min1!=-1)
				{
					min2=min1;
					*p2=*p1;
				}
				min1=T[j].weight;
				*p1=j;
			}
			else
				if(T[j].weight<min2||min2==-1)
				{
					min2=T[j].weight;
					*p2=j;
				}
		}
}

void CharSetHuffmanEncoding(HuffmanTree T,HuffmanCode H)
{	//根據(jù)Huffman樹T求Huffman編碼表H
	int c,p,i;				//c和p分別指示T中孩子和雙親的位置
	char cd[n+1];			//臨時存放編碼
	int start;				//指示編碼在cd中的起始位置
	cd[n]='\0';				//編碼結(jié)束符
	printf("請輸入字符:");
	for(i=0;i<n;i++)
	{H[i].ch=getchar();
	}
	for(i=0;i<n;i++)		//依次求葉子T[i]的編碼
	{
			//讀入葉子T[i]對應(yīng)的字符
		start=n;			//編碼起始位置的初值
		c=i;				//從葉子T[i]開始上溯
		while((p=T[c].parent)!=NULL)//直至上溯到T[c]是樹根為止
		{	//若T[c]是T[p]的左孩子,則生成代碼0;否則生成代碼1
			cd[--start]=(T[p].lchild==c)?'0':'1';
			c=p;			//繼續(xù)上溯
		}
		strcpy(H[i].bits,&cd[start]);		//復(fù)制編碼位串
	}
	for(i=0;i<n;i++)
		printf("第%d個字符%c的編碼為%s\n",i+1,H[i].ch,H[i].bits);
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美综合在线观看第十页| 国产精品久久久久三级| 成人一区二区三区| 午夜精品久久久| 中文字幕一区在线| 日韩欧美视频一区| 欧美三级蜜桃2在线观看| 国产精品一区一区| 奇米精品一区二区三区四区| 一区在线中文字幕| 久久毛片高清国产| 欧美一区二区三区精品| 91香蕉视频mp4| 国产69精品久久777的优势| 青青草国产成人av片免费| 亚洲激情av在线| 国产精品无码永久免费888| 日韩欧美国产一区二区在线播放| 在线视频你懂得一区二区三区| 成人免费av资源| 韩日av一区二区| 免费欧美在线视频| 亚洲.国产.中文慕字在线| 国产精品免费视频网站| 国产日韩在线不卡| 亚洲精品在线观看网站| 欧美高清激情brazzers| 欧洲在线/亚洲| 日本精品裸体写真集在线观看 | 丝袜诱惑亚洲看片| 亚洲天堂成人网| 中文字幕日韩一区| 国产精品女人毛片| 一区二区中文视频| 亚洲图片你懂的| 中文字幕字幕中文在线中不卡视频| 久久久久久亚洲综合影院红桃| 日韩免费一区二区三区在线播放| 欧美日韩视频在线第一区| 欧美视频完全免费看| 欧美亚洲综合色| 欧美男生操女生| 67194成人在线观看| 制服丝袜在线91| 欧美mv日韩mv国产网站app| 亚洲精选免费视频| 专区另类欧美日韩| 一二三区精品视频| 亚洲123区在线观看| 日韩不卡手机在线v区| 日本不卡一区二区| 精品午夜一区二区三区在线观看 | 精品一区二区三区不卡| 美日韩一区二区| 极品瑜伽女神91| 国产成人免费av在线| 成人黄色777网| 91久久精品网| 在线成人午夜影院| 久久免费午夜影院| 中文字幕一区三区| 亚洲国产wwwccc36天堂| 日本aⅴ免费视频一区二区三区 | 欧美在线观看一区二区| 91.com视频| 国产清纯在线一区二区www| 中文字幕中文乱码欧美一区二区 | 亚洲曰韩产成在线| 日韩高清不卡一区二区| 国产永久精品大片wwwapp| 成人视屏免费看| 欧美区在线观看| 久久久久久久久久久久久女国产乱| 国产精品免费看片| 午夜电影一区二区三区| 国产精品自在在线| 日本久久电影网| 精品国产乱码久久久久久闺蜜| 欧美国产1区2区| 丝袜国产日韩另类美女| 国产成人免费网站| 欧美三区在线视频| 国产人久久人人人人爽| 亚洲国产精品久久久男人的天堂| 极品少妇xxxx精品少妇偷拍| av不卡免费电影| 欧美成人猛片aaaaaaa| 一区精品在线播放| 精品一区二区三区视频| 一本色道**综合亚洲精品蜜桃冫| 欧美一区二区人人喊爽| 国产精品国产三级国产aⅴ入口| 日产国产欧美视频一区精品 | 东方aⅴ免费观看久久av| 欧美在线视频你懂得| 久久久久久久久久久久久久久99| 亚洲中国最大av网站| 国产黑丝在线一区二区三区| 欧洲av在线精品| 亚洲国产经典视频| 日韩不卡一二三区| 欧美性xxxxx极品少妇| 欧美国产成人精品| 狠狠色丁香九九婷婷综合五月| 欧美视频一区二区三区四区 | 亚洲电影中文字幕在线观看| 懂色一区二区三区免费观看| 日韩欧美一级二级| 无吗不卡中文字幕| 91福利资源站| 亚洲欧美偷拍三级| 国产91精品欧美| 精品国产乱码久久久久久牛牛| 亚洲成在线观看| 欧美中文字幕一区二区三区| 国产欧美视频在线观看| 看电影不卡的网站| 91麻豆精品国产91| 亚洲一区二区偷拍精品| 91社区在线播放| 国产精品萝li| 国产99精品国产| 国产亚洲一本大道中文在线| 久久国产精品色| 日韩午夜精品电影| 日韩av午夜在线观看| 欧美高清激情brazzers| 亚洲不卡一区二区三区| 在线免费观看日本一区| 亚洲精品美国一| av电影天堂一区二区在线观看| 中文字幕精品在线不卡| 国产成人免费视频| 国产精品婷婷午夜在线观看| 国产乱色国产精品免费视频| 久久网站最新地址| 国产99一区视频免费| 欧美国产禁国产网站cc| 成人18精品视频| 中文字幕一区二| 91视频国产资源| 亚洲精品少妇30p| 91久久国产综合久久| 亚洲理论在线观看| 欧美丝袜丝交足nylons| 亚洲国产毛片aaaaa无费看| 欧美日韩中字一区| 日本不卡高清视频| 欧美va亚洲va在线观看蝴蝶网| 日本不卡一区二区三区| 欧美精品一区二区三区蜜臀| 国产一区二区三区香蕉| 国产欧美日韩另类一区| 99久久久国产精品免费蜜臀| 夜夜揉揉日日人人青青一国产精品 | 久久久久久久久久久电影| 国产成人av网站| 亚洲日本电影在线| 欧美日韩高清影院| 极品少妇xxxx偷拍精品少妇| 国产精品女主播在线观看| 在线中文字幕一区二区| 婷婷丁香激情综合| www成人在线观看| 972aa.com艺术欧美| 日韩制服丝袜av| 久久久91精品国产一区二区三区| 不卡的av网站| 亚洲大片精品永久免费| 337p粉嫩大胆噜噜噜噜噜91av| 成人福利视频网站| 午夜av一区二区三区| 亚洲精品在线免费观看视频| 99国产麻豆精品| 日本中文字幕一区| 欧美激情在线看| 亚洲综合激情另类小说区| 日韩欧美专区在线| 不卡的电视剧免费网站有什么| 石原莉奈在线亚洲三区| 国产精品午夜在线观看| 欧美日韩国产另类不卡| 国产**成人网毛片九色| 亚洲午夜三级在线| 国产校园另类小说区| 欧美视频一区二| 成人高清视频在线| 麻豆国产精品官网| 曰韩精品一区二区| 国产喷白浆一区二区三区| 91精品欧美一区二区三区综合在| 丁香桃色午夜亚洲一区二区三区| 午夜精品久久久久久久久| 国产精品乱码久久久久久| 337p亚洲精品色噜噜狠狠| 91免费版在线| 国产成人免费在线观看不卡| 免费人成黄页网站在线一区二区| 亚洲美女一区二区三区| 国产日产欧美一区|