哈夫曼树的创建

本文介绍了哈夫曼树的概念,并详细讲述了如何在Java中创建哈夫曼树,包括创建树节点、构建过程以及测试步骤。通过初始化节点列表、升序排序、组合节点和中序遍历来确保哈夫曼树的正确构建。
摘要由CSDN通过智能技术生成

哈夫曼树

1. 什么是哈夫曼树

在这里插入图片描述

2. 创建哈夫曼树

2.1 创建树节点TreeNode

//树的节点
public class TreeNode {
   
    /**
     * 值
     * 左右孩子
     */
    private int value;
    public TreeNode left;
    public TreeNode right;

    public TreeNode() {
   

    }

    public TreeNode(int value) {
   
        this.value = value;
    }

    public int getValue() {
   
        return value;
    }

}

2.2 构建哈夫曼树

  首先,需要一个list来储存所有要被创建的节点,这里我是用LinkedList来实现List接口。创建完毕,就要对这个list初始化。
构建步骤:

  • 创建list,以及根节点root,对list进行初始化。
  • 对list进行升序排序,目的是为了找出value最小的两个节点。(我这里为了方便,用的选择排序,可以试试手撕快排)
  • 取出list最小的两个节点,然后创建父节点,再子父相连 。(一定要子父相连)
  • 最后,初始化根节点。
  • (后面中序遍历是为了测试建树是否正确)
//哈夫曼树
public class HfmTree {
   

    public TreeNode root = new TreeNode();
    public List<TreeNode> list 
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
哈夫曼树创建算法可以分为以下几步: 1. 统计每个字符在待编码字符串中出现的频率,并将其存储在一个数组中。 2. 将数组中的元素构建成森林,每个元素作为一棵只包含自己的树。 3. 选取森林中权值最小的两棵树进行合并,生成一棵新的树,新树的根节点权值为两棵树根节点权值之和。 4. 将新生成的树插入到森林中,并从森林中删除原来的两棵树。 5. 重复步骤3和步骤4,直到森林中只剩下一棵树,即哈夫曼树。 下面是一个基于数组实现的哈夫曼树创建算法的伪代码: ``` // 定义一个节点结构体 struct Node { int weight; // 权值 int parent; // 父节点 int left; // 左子节点 int right; // 右子节点 }; // 创建哈夫曼树的函数 void createHuffmanTree(Node *tree, int *weights, int n) { // 初始化森林,每个节点作为一棵只包含自己的树 for (int i = 0; i < n; i++) { tree[i].weight = weights[i]; tree[i].parent = -1; tree[i].left = -1; tree[i].right = -1; } // 合并森林中的树,直到森林中只剩下一棵树 for (int i = 0; i < n - 1; i++) { int min1 = INT_MAX, min2 = INT_MAX; // 记录森林中权值最小的两棵树 int min1Index = -1, min2Index = -1; // 在森林中找到权值最小的两棵树 for (int j = 0; j < n + i; j++) { if (tree[j].parent == -1) { // 只考虑还没有被合并的树 if (tree[j].weight < min1) { min2 = min1; min2Index = min1Index; min1 = tree[j].weight; min1Index = j; } else if (tree[j].weight < min2) { min2 = tree[j].weight; min2Index = j; } } } // 合并权值最小的两棵树 tree[min1Index].parent = n + i; tree[min2Index].parent = n + i; tree[n + i].weight = tree[min1Index].weight + tree[min2Index].weight; tree[n + i].left = min1Index; tree[n + i].right = min2Index; } } ``` 在这个算法中,我们使用了一个节点结构体来表示哈夫曼树中的每个节点,包括节点的权值、父节点、左子节点和右子节点。我们首先初始化森林,每个节点作为一棵只包含自己的树。然后,我们重复执行选择权值最小的两棵树进行合并的操作,直到森林中只剩下一棵树为止。最终生成的树就是哈夫曼树
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值