贪心算法哈夫曼java_有没有童鞋可以把书上的用贪心算法实现的哈夫曼编码补全呀?...

public class Huffman {

Bintree tree;

float weight;

private Huffman(Bintree tt, float ww) {

tree = tt;

weight = ww;

}

public static Bintree huffmanTree(float[] f) {

//生成单结点数

int n = f.length;

Huffman[] w = new Huffman[n+1];

Bintree zero = new Bintree();

for(int i=0;i

Bintree x = new Bintree();

x.makeTree(new MyInteger(i), zero, zero);

w[i+1] = new Huffman(x, f[i]);

}

//建优先队列

MinHeap H = new MinHeap();

H.initialize(w, n);

//反复合并最小频率树

for(int i=1;i

Huffman x = (Huffman) H.removeMin();

Huffman y = (Huffman) H.removeMin();

Bintree z = new Bintree();

z.makeTree(null, x.tree, y.tree);

Huffman t = new Huffman(z, x.weight+y.weight);

H.put(t);

}

return ((Huffman) H.removeMin()).tree;

}

}

书上只有这么点,有些类和方法都没有写,自己算法太弱了,明天就要考试了(伤心)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值