Huffman tree的C#实现

1. 结构类型定义:

 

     public   class  HuffmanTree
    {
        
public   int  Weight {  set get ; }
        
public  HuffmanTree Left {  set get ; }
        
public  HuffmanTree Right {  set get ; }
    }

 

 

2. 构建树:

 

ExpandedBlockStart.gif 代码
         public   static  HuffmanTree CreateHuffmanTree( int [] data)
        {
            
if  (data  ==   null   ||  data.Length  <   1 )
            {
                
throw   new  Exception( " data " );
            }

            IList
< HuffmanTree >  list  =   new  List < HuffmanTree > ();
            
foreach  (var d  in  data)
            {
                list.Add(
new  HuffmanTree
                {
                    Weight 
=  d,
                    Left 
=   null ,
                    Right 
=   null
                });
            }

            HuffmanTree parent 
=   new  HuffmanTree();
            HuffmanTree left 
=   new  HuffmanTree();
            HuffmanTree right 
=   new  HuffmanTree();

            
while  (list.Count  >   1 )
            {
                left 
=  list.First(item  =>  item.Weight  ==  list.Min(i  =>  i.Weight));
                list.Remove(left);
                right 
=  list.First(item  =>  item.Weight  ==  list.Min(i  =>  i.Weight));
                list.Remove(right);

                parent 
=   new  HuffmanTree
                {
                    Weight 
=  left.Weight  +  right.Weight,
                    Left 
=  left,
                    Right 
=  right
                };
                list.Add(parent);
            }

            
return  parent;
        }

 

 

3. 测试:

 

             int [] data  =  {  7 , 5 , 2 , 4 };
            HuffmanTree tree 
=  HuffmanCode.CreateHuffmanTree(data);

 

 download

转载于:https://www.cnblogs.com/Langzi127/archive/2010/07/22/1783255.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值