import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* @author chenyi
* @Description 构建赫夫曼树
* @date 2022/2/21 10:06
*/
public class HuffmanTree {
public static void main(String[] args) {
int[] arr = {13,7,8,3,29,6,1};
Node root = createHuffmanTree(arr);
// 输出来看看
perOrder(root);
}
public static void perOrder(Node node){
if(node==null) {
return;
}
System.out.print(node.val + " ");
perOrder(node.left);
perOrder(node.right);
}
private static Node createHuffmanTree(int[] arr) {
// 将整数数组变为节点集合
List<Node> nodeList = new ArrayList<>();
for (int i = 0; i < arr.length; i++) {
nodeList.add(new Node(arr[i]));
}
while (nodeList.size()>1) {
Collections.sort(nodeList);
// 取出最小的两个节点,两个节点之后构建出第三个节点
Node node1 = nodeList.remove(0);
Node node2 = nodeList.remove(0);
Node node3 = new Node(node1.val+node2.val);
node3.left = node1;
node3.right = node2;
nodeList.add(node3);
}
return nodeList.get(0);
}
}
class Node implements Comparable<Node>{
int val;
Node left;
Node right;
@Override
public int compareTo(Node o) {
return this.val-o.val;
}
public Node(int val) {
this.val = val;
}
}
构建赫夫曼树
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 赫夫曼树的概念 要了解赫夫曼树,我们要首先从扩充二叉树说起 二叉树结点的度 结点的度指的是二叉树结点的分支数目, ...
- 赫夫曼树创建思路图解 给你一个数列{13,7,8,3,29,6,1},要求转成一颗赫夫曼树思路分析(示意图): 构...
- 最佳实践-数据压缩(创建赫夫曼树) 将给出的一段文本,比如"i like like like java do yo...
- from:http://data.biancheng.net/view/33.html 赫夫曼树,别名“哈夫曼树”...