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

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

?? 哈夫曼樹.cpp

?? c++ 實現的huffman樹的操作
?? CPP
字號:
//* * * * * * * * * * * * * * * * * * * * * * * *
//*CHAPTER          :4  (4_4)                   *
//*PROGRAM          :哈夫曼樹                   *
//*CONTENT          :構造哈夫曼樹,哈夫曼編碼    *
//* * * * * * * * * * * * * * * * * * * * * * * *
#include <dos.h>
#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct
{unsigned int weight;  //結點權值
 unsigned int parent,lchild,rchild; //結點的父指針,左右孩子指針
}HTNode,*HuffmanTree;       //動態分配數組存儲哈夫曼樹
typedef char **HuffmanCode; //動態分配數組存儲哈夫曼編碼表
void CreateHuffmanTree(HuffmanTree &,unsigned int*,int ); //生成一棵哈夫曼樹
void HuffmanCoding(HuffmanTree,HuffmanCode &,int );       //對哈夫曼樹進行編碼
void PrintHuffmanCode(HuffmanCode,unsigned int*,int);     //顯示哈夫曼編碼
void Select(HuffmanTree,int,int&,int&); //在數組中尋找權值最小的兩個結點
void main()
{HuffmanTree HT;  //哈夫曼樹HT
 HuffmanCode HC;  //哈夫曼編碼表HC
 int n,i;         //n是哈夫曼樹葉子結點數
 unsigned int *w; //w存放葉子結點權值   
 char j='y';
 textbackground(3);  //設定屏幕顏色
 textcolor(15);
 clrscr();
 //程序解說
 printf("本程序將演示構造哈夫曼樹.\n");
 printf("首先輸入葉子結點數目.\n例如:8\n");
 printf("然后輸入每個葉子結點的權值.\n");
 printf("例如:5 29 7 8 14 23 3 11\n");
 printf("程序會構造一棵哈夫曼樹并顯示哈夫曼編碼.\n");
 printf("  5---0110\n 29---10\n  7---1110\n  8---1111\n 14---110\n");
 printf(" 23---00\n  3---0111\n 11---010\n");
 while(j!='N'&&j!='n')
      {printf("請輸入葉子結點數目:");
       scanf("%d",&n);   //輸入葉子結點數
       if(n<=1) {printf("該數不合理!\n");continue;}
       w=(unsigned int*)malloc(n*sizeof(unsigned int)); //開辟空間存放權值
       printf("請輸入各葉子結點的權值:\n");
       for(i=0;i<n;i++) scanf("%d",&w[i]);   //輸入各葉子結點權值
       CreateHuffmanTree(HT,w,n);       //生成哈夫曼樹
       HuffmanCoding(HT,HC,n);          //進行哈夫曼編碼
       PrintHuffmanCode(HC,w,n);        //顯示哈夫曼編碼
       printf("哈夫曼樹構造完畢,還要繼續嗎?(Y/N)");
       scanf(" %c",&j);
     }
}

void CreateHuffmanTree(HuffmanTree &HT,unsigned int *w,int n)
{//w存放n個結點的權值,將構造一棵哈夫曼樹HT
 int i,m;
 int s1,s2;
 HuffmanTree p;
 if(n<=1) return;
 m=2*n-1;  //n個葉子結點的哈夫曼樹,有2*n-1個結點
 HT=(HuffmanTree)malloc((m+1)*sizeof(HTNode)); //開辟2*n各結點空間,0號單元不用
 for(p=HT+1,i=1;i<=n;++i,++p,++w) //進行初始化
       {p->weight=*w;
	p->parent=0;
	p->lchild=0;
	p->rchild=0;
       }
 for(;i<=m;++i,++p)
       {p->weight=0;
	p->parent=0;
	p->lchild=0;
	p->rchild=0;
       }
 for(i=n+1;i<=m;++i)  //建哈夫曼樹
    {Select(HT,i-1,s1,s2);  
        //從HT[1...i-1]中選擇parent為0且weight最小的兩個結點,其序號分別為s1和s2
     HT[s1].parent=i; HT[s2].parent=i; //修改s1和s2結點的父指針parent
     HT[i].lchild=s1; HT[i].rchild=s2; //修改i結點的左右孩子指針
     HT[i].weight=HT[s1].weight+HT[s2].weight; //修改權值
    }
}
void HuffmanCoding(HuffmanTree HT,HuffmanCode &HC,int n)
{//將有n個葉子結點的哈夫曼樹HT進行編碼, 所編的碼存放在HC中
 //方法是從葉子到根逆向求每個葉子結點的哈夫曼編碼
 int i,c,f,start;
 char *cd;
 HC=(HuffmanCode)malloc((n+1)*sizeof(char *)); //分配n個編碼的頭指針向量
 cd=(char *)malloc(n*sizeof(char));  //開辟一個求編碼的工作空間
 cd[n-1]='\0';           //編碼結束符
 for(i=1;i<=n;++i)       //逐個地求哈夫曼編碼
    {start=n-1;          //編碼結束位置
     for(c=i,f=HT[i].parent;f!=0;c=f,f=HT[f].parent) //從葉子到根逆向求編碼
	if(HT[f].lchild==c)  cd[--start]='0';        //若是左孩子編為'0'
	else cd[--start]='1';                        //若是右孩子編為'1' 
     HC[i]=(char *)malloc((n-start)*sizeof(char));   //為第i個編碼分配空間
     strcpy(HC[i],&cd[start]);         //將編碼從cd復制到HC中
    }
 free(cd); //釋放工作空間
}
void PrintHuffmanCode(HuffmanCode HC,unsigned int *w,int n)
{//顯示有n個葉子結點的哈夫曼樹的編碼表
 int i;
 printf("HuffmanCode is :\n");
 for(i=1;i<=n;i++)
   {printf(" %3d---",w[i-1]);
    puts(HC[i]);
   }
 printf("\n");
}
void Select(HuffmanTree HT,int t,int&s1,int&s2)
{//在HT[1...t]中選擇parent不為0且權值最小的兩個結點,其序號分別為s1和s2 
 int i,m,n;
 m=n=10000;  
 for(i=1;i<=t;i++)
   {if(HT[i].parent==0&&(HT[i].weight<m||HT[i].weight<n))
	if(m<n)
	    {n=HT[i].weight;s2=i;}
	else {m=HT[i].weight;s1=i;}

   }
 if(s1>s2)  //s1放較小的序號
      {i=s1;s1=s2;s2=i;}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人黄色免费短视频| 成人av影视在线观看| 欧美国产综合一区二区| 色婷婷av一区二区三区gif| 美女在线视频一区| 亚洲伦理在线免费看| 精品国产一区二区三区久久久蜜月 | 一区二区三区中文免费| 欧美成人精品福利| 欧美性生活影院| 国产成a人亚洲精| 日韩中文字幕1| 亚洲欧美日韩国产综合| 久久精品人人爽人人爽| 91精品国产乱码| 欧美午夜一区二区| 99re6这里只有精品视频在线观看| 激情久久五月天| 偷拍一区二区三区四区| 最新日韩在线视频| 久久久九九九九| 日韩欧美一区电影| 欧美少妇性性性| 色综合一区二区| 成人成人成人在线视频| 国精产品一区一区三区mba视频| 天天综合天天综合色| 一区二区三区在线不卡| 国产精品免费视频一区| 久久久精品蜜桃| 精品国产伦一区二区三区观看体验| 欧美日本在线看| 亚洲综合在线观看视频| 国产精品午夜电影| 国产三级三级三级精品8ⅰ区| 欧美一二三区在线观看| 欧美精品aⅴ在线视频| 欧美午夜在线观看| 欧美三级在线看| 欧美综合视频在线观看| 色呦呦日韩精品| 91免费看片在线观看| 不卡一卡二卡三乱码免费网站| 国产不卡免费视频| 国产成人免费xxxxxxxx| 国产精品亚洲一区二区三区妖精| 久久99国产精品免费网站| 蜜桃视频一区二区| 狠狠色丁香久久婷婷综| 国产精品综合网| 国产成人一区二区精品非洲| 极品瑜伽女神91| 极品瑜伽女神91| 国产91富婆露脸刺激对白| 国产精品一区免费在线观看| 国产成人精品网址| 成人国产电影网| 99国产精品久久久| 色88888久久久久久影院野外| 欧美网站大全在线观看| 欧美一区二区观看视频| 久久夜色精品一区| 国产精品激情偷乱一区二区∴| 亚洲欧洲日韩综合一区二区| 亚洲免费av高清| 日本不卡视频在线| 国产剧情av麻豆香蕉精品| 岛国一区二区在线观看| 在线亚洲免费视频| 91麻豆精品国产自产在线观看一区 | 26uuu色噜噜精品一区二区| 久久久精品国产免费观看同学| 国产精品成人午夜| 亚洲成a人v欧美综合天堂下载| 免费观看在线综合| 丰满岳乱妇一区二区三区| 91麻豆产精品久久久久久 | 欧美做爰猛烈大尺度电影无法无天| 欧美视频在线观看一区二区| 日韩一卡二卡三卡四卡| 久久久久久日产精品| 中文字幕一区免费在线观看 | 国产精品自拍av| 91女厕偷拍女厕偷拍高清| 欧美二区三区的天堂| 国产欧美日本一区视频| 亚洲一级片在线观看| 精品一区二区在线观看| 9色porny自拍视频一区二区| 欧美一区二区三区在线观看视频| 国产欧美日韩精品一区| 午夜精品久久久久| 不卡影院免费观看| 日韩区在线观看| ...av二区三区久久精品| 日韩成人免费电影| 91免费在线播放| 国产真实精品久久二三区| 色婷婷久久久亚洲一区二区三区 | 国产一区二区三区久久悠悠色av| 91成人免费在线| 国产午夜亚洲精品午夜鲁丝片| 亚洲成人高清在线| 成人高清免费观看| 亚洲精品一区二区三区四区高清| 亚洲精品免费在线观看| 国产成人午夜精品5599| 欧美一区二区三区系列电影| 亚洲精品综合在线| 国产成人精品综合在线观看| 在线播放一区二区三区| 亚洲欧洲综合另类| 国产福利一区二区三区视频| 欧美一区二区视频在线观看2022 | 国精产品一区一区三区mba桃花 | 久久免费午夜影院| 美女诱惑一区二区| 欧美视频三区在线播放| 中文字幕在线不卡国产视频| 国产精品亚洲专一区二区三区| 欧美一区二区三区成人| 亚洲综合小说图片| 91丨九色丨蝌蚪富婆spa| 国产色综合一区| 国产一区二区视频在线播放| 91精品在线麻豆| 亚洲国产精品自拍| 日本道精品一区二区三区| 中文字幕一区二区三区不卡在线| 国产成人综合在线观看| 久久久久青草大香线综合精品| 久久精品国产色蜜蜜麻豆| 欧美一区二区三区视频免费播放| 性做久久久久久免费观看欧美| 91久久精品网| 亚洲青青青在线视频| 91蜜桃网址入口| 亚洲天堂中文字幕| 91无套直看片红桃| 亚洲欧美日韩国产一区二区三区| 成人精品小蝌蚪| 最新国产の精品合集bt伙计| www.亚洲在线| 亚洲欧洲国产日韩| 99re视频精品| 樱桃国产成人精品视频| 日本韩国视频一区二区| 一区二区成人在线观看| 欧美色精品天天在线观看视频| 亚洲bt欧美bt精品777| 欧美精品日韩一区| 久久精品国产一区二区| 久久日韩精品一区二区五区| 国产91在线观看| 国产精品福利一区| 色综合视频在线观看| 亚洲成人激情社区| 欧美xxxx老人做受| 成人夜色视频网站在线观看| 国产精品免费丝袜| 在线看国产一区| 日韩av电影天堂| 久久伊人蜜桃av一区二区| 国产99久久久精品| 亚洲免费在线观看| 91麻豆精品国产自产在线观看一区 | 欧洲精品一区二区| 奇米色777欧美一区二区| 精品久久久久av影院| www.亚洲在线| 午夜视黄欧洲亚洲| 久久奇米777| 99久久精品国产一区| 婷婷成人综合网| 久久婷婷国产综合国色天香 | 成人高清视频免费观看| 亚洲国产cao| 欧美videos中文字幕| 成人国产免费视频| 日韩国产欧美在线观看| 亚洲国产精品传媒在线观看| 在线观看网站黄不卡| 精品综合免费视频观看| 18欧美乱大交hd1984| 欧美一区永久视频免费观看| 成人激情免费视频| 婷婷丁香激情综合| 国产精品―色哟哟| 欧美日韩色一区| 高清beeg欧美| 亚洲大片在线观看| 国产精品免费免费| 欧美一二三在线| 色天使色偷偷av一区二区| 六月丁香婷婷色狠狠久久| 亚洲乱码中文字幕| 国产亚洲人成网站| 欧美一卡2卡三卡4卡5免费| 99久久久免费精品国产一区二区| 五月天中文字幕一区二区|