a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C# > 正文

C#求解哈夫曼樹,實(shí)例代碼

2020-01-24 03:27:01
字體:
供稿:網(wǎng)友

復(fù)制代碼 代碼如下:

  class HuffmanTree
    {
        private Node[] data;
        public int LeafNum { get; set; }
        public Node this[int index]
        {
            get { return data[index]; }
            set { data[index] = value; }
        }
        public HuffmanTree(int n)
        {
            data = new Node[2 * n - 1];
            for (int i = 0; i < 2 * n - 1; i++)
            {
                data[i] = new Node();
            }
            LeafNum = n;
        }
        public void Create(List<int> list)
        {
            int min1;
            int min2;
            int tmp1, tmp2;
            for (int i = 0; i < list.Count; i++)
            {
                data[i].Weight = list[i];
            }              
            for (int i = 0; i < LeafNum-1; i++)
            {
                min1 = min2 = int.MaxValue;
                tmp1 = tmp2 = 0;

               //獲取數(shù)組中最小的2個(gè)值
                for (int j = 0; j < LeafNum + i; j++)
                {
                    if (data[j].Weight<min1&&data[j].Parent == -1)
                    {
                        min2 = min1;
                        tmp2 = tmp1;
                        min1 = data[j].Weight;
                        tmp1 = j;
                    }
                   else if (data[j].Weight < min2 && data[j].Parent == -1)
                    {
                        min2 = data[j].Weight;
                        tmp2 = j;
                    }                
                }
                data[tmp1].Parent = this.LeafNum + i;
                data[tmp2].Parent = this.LeafNum + i;
                data[this.LeafNum + i].Weight = data[tmp1].Weight + data[tmp2].Weight;
                data[this.LeafNum + i].LChild = tmp1;
                data[this.LeafNum + i].RChild = tmp2;
            }
        }


//樹的結(jié)點(diǎn)(樹是用數(shù)組保存的) 

public class Node
    {
        public int Weight { get; set; }//權(quán)值
        public int LChild { get; set; }//左孩子在數(shù)組中的位置
        public int RChild { get; set; }//右孩子在數(shù)組中的位置
        public int Parent { get; set; }//父節(jié)點(diǎn)在數(shù)組中的位置
        public Node()
        {
            Weight = 0;
            LChild = -1;
            RChild = -1;
            Parent = -1;//-1表示沒有
        }
        public Node(int weight,int lChild,int rChild,int parent )
        {
            this.Weight = weight;
            this.LChild = lChild;
            this.RChild = rChild;
            this.Parent = parent;
        }
    }

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲国产精品麻豆 | 国产在线精品一区 | 国产三级视频 | 一级性视频 | 国产免费拔擦拔擦8x高清在线人 | 91精品久久久久久久久久 | 午夜精品一区二区三区在线观看 | 99热在线观看 | 国产精品成人3p一区二区三区 | 99精品视频久久精品视频 | www.超碰| 午夜影视在线观看 | 九九热精品视频 | 国产欧美日韩在线 | 欧美无遮挡 | 国产欧美日韩 | 久久久久久久久久久网站 | 成人一区二区三区四区 | av在线免费看片 | 太子妃好紧皇上好爽h | 国产福利在线观看视频 | 日韩视频在线一区二区 | 亚洲欧美另类图片 | 国产精品二区三区 | 香蕉在线影院 | 激情六月综合 | 韩国午夜av | 色欧美片视频在线观看 | 亚洲欧美日韩另类精品一区二区三区 | 日本精品久久 | 国产一区二区视频在线观看 | 亚洲黑人在线 | 精品日本一区二区 | 日本视频在线观看 | 日韩视频在线播放 | 神马久久久久久久久 | 国产精品极品美女在线观看免费 | 播放毛片 | 欧美精品在线一区二区三区 | 日本欧美在线 | 国产成人久久精品77777 |