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

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

?? huffman.c

?? huofuman 壓縮編碼 描述如何用霍夫曼編碼進行文件壓縮
?? C
字號:
/*
 * 程序功能:對文本文件success.dat進行霍夫曼編碼,用文本文件coding.dat保存編碼
 * 編程思路:
   第一步:
       首先打開掃描文件success.dat,統(tǒng)計出每個字符出現(xiàn)的次數(shù),作為各個字符的權,
   在這里我假設文本文件里面的字符只包含a~z這26個小寫字母,用CharCount函數(shù)掃描文件,統(tǒng)計
   出各個字符在文件中出現(xiàn)的次數(shù)(注意,如果某個字符一個都沒出現(xiàn),那就設它的權為1,因為權
   是0的話將不能正確編碼,血的教訓) CharCount函數(shù)的原型如下:
   void CharCount(FILE *fp, int *Count, int length);
   其中fp是要掃描的文件的指針,數(shù)組Count的每個元素分別用來統(tǒng)計a,b..z在文件中出現(xiàn)的次數(shù),
   length是數(shù)組的長度。

   第二步:
       根據(jù)給定的字符集(這里設字符集為a~z這26個小寫字母), 和各字符的權(用CharCount函數(shù)得到的),
   創(chuàng)建哈夫曼樹,函數(shù)原型如下:
   void createHTree(HuffmanTree HT, char *c, int *w, int n);
   其中數(shù)組c[0..n-1]就是要編碼的字符集,w[0..n-1]就是Count函數(shù)得到的各字符的權,構造霍夫曼樹HT

   第三步:
       對霍夫曼樹中的n個葉子結點進行編碼,第i個葉子結點的編碼存放在HC[i]中(1 <= i <= n)
	函數(shù)原型如下:
	void HuffmanCoding(HuffmanTree HT, HuffmanCode HC, int n);
	若中HT是構造的一棵霍夫曼樹,HC是一個字符串數(shù)組,n是霍夫曼樹葉子結點的數(shù)目

   第四步:
       對文本文件success.dat進行霍夫曼編碼,用文本文件coding.dat保存編碼,函數(shù)原型如下:
       void Coding(HuffmanTree HT, HuffmanCode HC, int n);
    其中HT是構造好的一棵霍夫曼樹,HC是保存著霍夫曼樹各葉子結點編碼的字符串數(shù)組,n是葉子結點
	的數(shù)目。
	    這個函數(shù)以讀方式打開success.dat和寫方式打開coding.dat,然后從success.dat里面讀一個字符,
	在字符串數(shù)組HC中找出該字符的編碼,寫入coding.dat文件,直到success.dat讀完為止。 

 * Copyright (c) 2006 All rights reserved.
 * 文件名:HuffmanCoding.c
 *
 * 文件標識:霍夫曼編碼
 * 摘要:對文本文件success.dat進行霍夫曼編碼,用文本文件coding.dat保存編碼
 * 輸入:無
 * 輸出:輸出一個霍夫曼編碼文件(文件內容是0或1的字符序)
 *
 * 當前版本 0.01
 * 作者:羅
 * 完成日期:2006年4月4日
 */


#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAXLEAFNUM 50    /* 葉子結點的最大數(shù)目 */

/* 定義一個霍夫曼樹的結構 */
typedef struct node
{
    char ch;                   /* 當前結點表示的字符,對于非葉子結點,此域不用 */
	int weight;                /* 當前結點的權值 */
    int parent;                /* 當前結點的父結點下標,為0表示無父結點 */
    int lchild, rchild;        /* 當前結點左右孩子結點的下標,都為0時表示無孩子結點 */
} HuffmanTree[2*MAXLEAFNUM];
typedef char* HuffmanCode[MAXLEAFNUM+1];

/* 在HT[1~n]中選擇weigth最小的且parent為0的結點,用p1,p2帶回 */
void select(HuffmanTree HT, int n, int *p1, int *p2);

/* 根據(jù)給定的字符集創(chuàng)建哈夫曼樹 */
void createHTree(HuffmanTree HT, char *c, int *w, int n);

/* n個葉子結點在霍夫曼樹HT中的下標為1~n,第i(i<=i<=n)個葉子的編碼存放HC[i]中 */
void HuffmanCoding(HuffmanTree HT, HuffmanCode HC, int n);

/* 利用具有n個字符的霍夫曼編碼的編碼集(1~n)對字符逐個進行編碼 */
/* 最后把編碼存儲在buff 所指向的字符指針中 */
void Coding(HuffmanTree HT, HuffmanCode HC, int n);


/* 統(tǒng)計字符在文件中出現(xiàn)的次數(shù),并作為該字符的權進行霍夫曼編碼 */
void CharCount(FILE *fp, int *Count, int length);

//函數(shù)功能:在HT[1~n]中選擇weigth最小的且parent為0的結點,用p1,p2帶回
//參數(shù):HT為n棵霍夫曼樹,p1和p2用來帶回weight最小的且parent為0的兩個結點
//返回值:無
void select(HuffmanTree HT, int n, int *p1, int *p2)
{
	static int first = 1;
	int k, i;
	while (HT[first].parent != 0)
		first++;
	k = first;
	for (i = first+1; i <= n; i++)
	if ((HT[i].parent == 0) && (HT[i].weight < HT[k].weight))
	{
		k = i;
	}
	if (k = first)
	{
		first++;
		while (HT[first].parent != 0)
			first++;
	}
	*p1 = k;

	k = first;
	for (i = first+1; i <= n; i++)
	if ((HT[i].parent == 0) && (HT[i].weight < HT[k].weight) &&(i != *p1))
	{
		k = i;
	}
	if (k == first)
	{
		first++;
		while (HT[first].parent != 0)
			first++;
	}
	*p2 = k;
}


/* 
 * 函數(shù)功能:創(chuàng)建霍夫曼樹
 * 參數(shù):數(shù)組c[0..n-1]和w[0..n-1]存放了n個字符,以及其概率,構造霍夫曼樹HT
 * 返回值:無
*/
void createHTree(HuffmanTree HT, char *c, int *w, int n)
{
	int i, s1, s2;
	if (n <= 1)
		return;
	/* 根據(jù)n個權值構造n棵只有根結點的二叉樹 */
	for (i = 1; i <= n; i++)
	{
		HT[i].ch = c[i-1];
		HT[i].weight = w[i-1];
		HT[i].parent = HT[i].lchild = HT[i].rchild = 0;
	}

	for (; i < 2*n; i++)
	{
		HT[i].parent = HT[i].lchild = HT[i].rchild = 0;
	}

	/* 構造霍夫曼樹,從HT[1.. i-1]中選擇parent 為0,且weight最小的兩棵樹,其序號為s1和s2 */
    for (i = n+1; i < 2*n; i++)
	{
		select(HT, i-1, &s1, &s2);
		HT[s1].parent = i;
		HT[s2].parent = i;
		HT[i].lchild = s1;
		HT[i].rchild = s2;
		HT[i].weight = HT[s1].weight + HT[s2].weight;
	}
}

/* 
 * 函數(shù)功能:對霍夫曼樹中的葉子結點進行編碼,第i個結點的編碼放在HC[i]中(1 <= i <= n)
 * 參數(shù):HT為一棵霍夫曼樹,HC為一個存放霍夫曼編碼的字符串數(shù)組,n為葉子的個數(shù)
 * 返回值:無
*/
void HuffmanCoding(HuffmanTree HT, HuffmanCode HC, int n)
{
    /*n個葉子結點在霍夫曼樹HT中的下標為1~n,第i(i<=i<=n)個葉子的編碼存放HC[i]中*/
    char *cd;
    int i, start, c, f;
    if (n <= 1)
        return;
    cd = (char *)malloc(n);
    cd[n-1] = '\0';
    i = 1;
    while (i <= n)
    {
        start = n-1;
        for (c=i, f=HT[c].parent; f!=0; c=f, f=HT[c].parent)
        {
            if (HT[f].lchild == c)
               cd[--start] = '1';
            else
               cd[--start] = '0';
        }
        HC[i] = (char *)malloc(n - start);
        strcpy(HC[i], &cd[start]);
        i++;
    } 
}


/*
 * 函數(shù)功能: 利用具有n個字符的霍夫曼編碼的編碼集(1~n)對字符逐個進行編碼
 * 最后把編碼存儲在buff 所指向的字符指針中
 * 參數(shù):一棵霍夫曼樹,字符集
*/
void Coding(HuffmanTree HT, HuffmanCode HC, int n)
{
	char ch;
	int i;
	FILE *IN, *OUT;

	if ((IN = fopen("success.dat", "r")) == NULL)
	{
		printf("File Open Error!\n");
		exit(1);
	}

	if ((OUT = fopen("coding.dat", "w+")) == NULL)
	{
		printf("File Open Error!\n");
		exit(1);
	}

	while (!feof(IN))
	{
		ch = fgetc(IN);
		i = 1;
		while ((HT[i].ch != ch) && (i <= n))
		{
			i++;
			if (i > n)
				return;
		}

		/* 將ch代表的字符的編碼寫入到輸出文件 */
		fputs(HC[i], OUT);
	}

	fclose(IN);
	fclose(OUT);
}


/*
 * 函數(shù)名:CharCount
 * 參數(shù):一個指向文件的指針,以及一個整型數(shù)組
 * 函數(shù)功能:統(tǒng)計文件中每個字符出現(xiàn)的次數(shù),由Count數(shù)組帶回字符出現(xiàn)的次數(shù)
 * 返回值:無
*/
void CharCount(FILE *fp, int *Count, int length)
{
	char ch;
	int i;
	/* 如果某個字符在文件中沒有出現(xiàn),則它的權為1 */
	for (i = 0; i < length; i++)
	{
		Count[i]++;
	}

	/* 碰到一個出現(xiàn)的字符,就將它的權增1 */
	while (!feof(fp))
	{
		ch = fgetc(fp);
		Count[(ch) - 97]++;
	}
}

int main(int argc, char* argv[])
{
	/* 要進行霍夫曼編碼的字符集 */
    char CharSet[] = "abcdefghijklmnopqrstuvwxyz";

    /* 字符的權 */
    static int weight[26];

	/* 字符集字符個數(shù) */
	int size, i;
    
	/* 霍夫曼樹變量 */

    HuffmanTree HT;
	/* 霍夫曼編碼集 */
	HuffmanCode HC;

	FILE *IN;

	if ((IN = fopen("success.dat", "r")) == NULL)
	{
		printf("File Open Error!\n");
		exit(1);
	}


	size = strlen(CharSet); 
	/* 統(tǒng)計各個字符在文件中出現(xiàn)的次數(shù) */
    CharCount(IN, weight, size);

	/* 輸出各字符在文件中出現(xiàn)的次數(shù),次數(shù)為1表示在文件中沒有出現(xiàn)該字符 */
	printf("各個字符的權為:\n");
	for (i = 0; i < size; i++)
	{
		printf("%3d", weight[i]);
		if ((i+1) % 10 == 0)
			printf("\n");
	}
	printf("\n");
	fclose(IN);

	/* 根據(jù)字符集和權值創(chuàng)建霍夫曼樹 */
	createHTree(HT, CharSet, weight, size);

	/* 對哈夫曼樹中的葉子結點進行編碼 */
	HuffmanCoding(HT, HC, size);
	/* 輸出各個字符對應的編碼 */
	printf("各個字符的編碼分別為:\n");
	for (i = 1; i <= size; i++)
	{
		printf("%c = %s\n", HT[i].ch, HC[i]);
	}

	/* 對文件進行編碼,執(zhí)行完后看看你的當前工作目錄下的coding.dat文件,是不是有字符編碼了 */
	Coding(HT, HC, size);

	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区在线观看视频| 欧美日韩精品电影| 国产精品妹子av| 国产成人精品在线看| 国产午夜精品在线观看| av资源网一区| 一区二区在线观看不卡| 欧美午夜精品久久久久久超碰| 午夜成人免费电影| 精品国产亚洲在线| 成人精品高清在线| 一区二区三区91| 欧美一区二区三区公司| 国产经典欧美精品| 亚洲三级免费观看| 在线不卡中文字幕播放| 国产尤物一区二区| 亚洲免费av网站| 欧美日韩高清不卡| 国产精品996| 亚洲成人一区在线| 久久久久久久久久久99999| 91麻豆国产自产在线观看| 亚洲va国产天堂va久久en| 久久久久久久久久久99999| 色婷婷狠狠综合| 老色鬼精品视频在线观看播放| 国产精品久久久久久久久晋中| 欧美在线观看18| 国产老肥熟一区二区三区| 亚洲精品成人精品456| 精品福利二区三区| 欧美性做爰猛烈叫床潮| 国产精品自在在线| 亚洲chinese男男1069| 中文欧美字幕免费| 91精品国产综合久久香蕉的特点| 成人午夜精品在线| 蜜桃视频一区二区三区在线观看 | 国产一区二区三区观看| 亚洲三级免费观看| 久久久99久久精品欧美| 欧美三级中文字幕在线观看| 成人网页在线观看| 蜜桃视频第一区免费观看| 亚洲三级在线观看| 欧美国产激情一区二区三区蜜月| 91精品国产综合久久精品app| 99综合电影在线视频| 精品中文字幕一区二区| 亚洲一区二区精品视频| 国产精品美女久久久久久久| 日韩免费视频一区| 欧美久久久久久久久中文字幕| 99久久99久久久精品齐齐| 国产乱理伦片在线观看夜一区| 日韩在线观看一区二区| 一区二区三区鲁丝不卡| 最新中文字幕一区二区三区| 久久久久国色av免费看影院| 日韩视频一区二区三区在线播放| 欧美色综合久久| 日本欧美在线看| 久久久久久影视| 欧美一级理论片| 337p亚洲精品色噜噜| 一本到三区不卡视频| 国产99精品视频| 国产盗摄精品一区二区三区在线| 精品综合免费视频观看| 久久精品国产99国产| 美女任你摸久久| 另类人妖一区二区av| 久久黄色级2电影| 青娱乐精品视频| 久久99国产精品免费| 黑人精品欧美一区二区蜜桃| 国产一区二区三区高清播放| 国产麻豆精品视频| 精品在线一区二区三区| 九九**精品视频免费播放| 久久精品国产亚洲a| 精品一区二区三区影院在线午夜| 另类调教123区| 国产伦精一区二区三区| 国产成人一区二区精品非洲| 国产xxx精品视频大全| 国产69精品久久久久777| 白白色亚洲国产精品| 91偷拍与自偷拍精品| 在线观看日韩电影| 欧美一区二区三区爱爱| 精品国产凹凸成av人导航| 久久九九99视频| 亚洲天堂久久久久久久| 一区二区日韩电影| 蜜桃在线一区二区三区| 国产剧情一区在线| 一本一本久久a久久精品综合麻豆| 一本久久a久久免费精品不卡| 欧美在线观看18| 精品久久久久av影院| 日本一区二区三区国色天香 | 久久久亚洲欧洲日产国码αv| 国产精品私人影院| 亚洲午夜久久久久久久久电影院| 日本成人在线网站| 风间由美一区二区三区在线观看| 色综合一个色综合| 7777精品久久久大香线蕉| 亚洲精品一线二线三线无人区| 欧美高清在线视频| 亚洲国产aⅴ天堂久久| 精品一区二区日韩| 色综合夜色一区| 精品国产91乱码一区二区三区| 亚洲蜜臀av乱码久久精品| 理论电影国产精品| 色播五月激情综合网| 精品国产髙清在线看国产毛片 | 欧美日韩日日摸| 国产丝袜在线精品| 亚洲成人黄色影院| 不卡一区二区三区四区| 91精品视频网| 亚洲欧美日韩在线不卡| 韩国毛片一区二区三区| 在线观看网站黄不卡| 久久精品日产第一区二区三区高清版| 亚洲综合一二三区| 国产成人免费av在线| 91精品国产麻豆国产自产在线| 中文字幕一区在线观看| 极品少妇一区二区三区精品视频| 色94色欧美sute亚洲线路一ni| 精品国产乱码久久| 日韩国产一二三区| 一本色道久久综合亚洲精品按摩 | 亚洲欧美偷拍卡通变态| 国产一区二区三区最好精华液| 欧美色倩网站大全免费| 中文字幕亚洲视频| 国产精品一区二区不卡| 日韩一级片网址| 亚洲丰满少妇videoshd| 色中色一区二区| 国产精品久久久久9999吃药| 精油按摩中文字幕久久| 欧美一区二区视频在线观看2020| 夜夜爽夜夜爽精品视频| www..com久久爱| 欧美国产精品专区| 国产成人精品免费视频网站| 精品粉嫩超白一线天av| 久久99久久久久久久久久久| 欧美疯狂做受xxxx富婆| 亚洲综合久久久| 91精品福利视频| 夜夜精品视频一区二区| 日本国产一区二区| 亚洲综合一二三区| 91黄色免费看| 亚洲午夜免费视频| 欧美日韩中文字幕一区二区| 亚洲一区二区黄色| 欧美日韩久久久一区| 香蕉成人伊视频在线观看| 精品视频1区2区| 日韩综合一区二区| 欧美精品丝袜中出| 麻豆国产精品官网| 精品av综合导航| 国产99精品在线观看| **欧美大码日韩| 欧美天堂亚洲电影院在线播放| 亚洲午夜在线视频| 51久久夜色精品国产麻豆| 首页国产欧美日韩丝袜| 日韩精品在线网站| 福利视频网站一区二区三区| 国产精品免费人成网站| 91麻豆蜜桃一区二区三区| 亚洲一区视频在线| 欧美一级夜夜爽| 国产福利一区二区三区| 亚洲天堂久久久久久久| 欧美精品乱码久久久久久| 久久精品国产99国产| 中文字幕精品—区二区四季| 日本国产一区二区| 蜜桃视频在线观看一区| 国产精品区一区二区三区| 一本色道亚洲精品aⅴ| 日本不卡在线视频| 久久久99精品久久| 在线影院国内精品| 精品一区二区三区免费视频| 国产精品国产三级国产aⅴ原创| 日本国产一区二区| 久久av老司机精品网站导航|