哈夫曼树——洛谷 P2168 荷马史诗

https://daniu.luogu.org/problem/show?pid=2168
哈夫曼树话说是初赛的知识;
想当年prayer教初赛也是很怀念的呢;

有 N 个数Ai,每次可以挑两个数字 u 和 v直到只留留下
一个,花费 u + v 的代价删除 u 和 v 并加入 u + v.
|
等价描述:
!|
给每个数字分配一个二进制串串,要求二进制串串没有一
个是另一个的前缀,要
求A[i]*Len[i]之和最小

为什么呢?
比如我们有4个单词,出现次数是1 2 3 4;
这里写图片描述

取两个最小的;
这里写图片描述
再重复
这里写图片描述
这里写图片描述
那么最后我们就可以统计答案;

这里写图片描述
所以我们用堆去模拟这个过程;
就好了;
如果进制是k,点数是n;

先添加若干个0直到数字个数满足(N-1)%(K-1)=0

显然;

#include<bits/stdc++.h>
#define Ll long long
using namespace std;
const Ll N=1e5+5;
struct di{
    Ll v,deep;
    bool operator <(const di &a)const{
        if(v!=a.v)return v>a.v;
        return deep>a.deep;
    }
}d[N*10];
priority_queue<di>Q;
Ll n,m,x,y,z,w,ans;
int main()
{
    scanf("%lld%lld",&n,&m);
    for(Ll i=1;i<=n;i++)scanf("%lld",&d[i].v),Q.push(d[i]);
    w=n;
    while((w-1)%(m-1))Q.push(d[++w]);
    for(Ll p=(w-1)/(m-1);p;p--){
        w++;
        for(Ll i=1;i<=m;i++){
            di k=Q.top();Q.pop();
            d[w].v+=k.v;
            d[w].deep=max(d[w].deep,k.deep);
        }
        d[w].deep++;
        ans+=d[w].v;
        Q.push(d[w]);
    }
    printf("%lld\n%lld",ans,d[w].deep);
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
(Huffman Tree)是一种特殊的二叉,用于数据压缩和编码。它的构建过程是根据字符出现的频率来确定每个字符的编码,使得出现频率高的字符具有较短的编码,而出现频率低的字符具有较长的编码。 以下是一个Python实现的哈的例子: ```python class TreeNode: def __init__(self, value, freq): self.value = value self.freq = freq self.left = None self.right = None def build_huffman_tree(char_freq): nodes = [TreeNode(char, freq) for char, freq in char_freq.items()] while len(nodes) > 1: nodes = sorted(nodes, key=lambda x: x.freq) left_node = nodes.pop(0) right_node = nodes.pop(0) parent_node = TreeNode(None, left_node.freq + right_node.freq) parent_node.left = left_node parent_node.right = right_node nodes.append(parent_node) return nodes[0] def encode_huffman_tree(root, code='', codes={}): if root is None: return if root.value is not None: codes[root.value] = code encode_huffman_tree(root.left, code + '0', codes) encode_huffman_tree(root.right, code + '1', codes) return codes def decode_huffman_tree(root, encoded_text): decoded_text = '' current_node = root for bit in encoded_text: if bit == '0': current_node = current_node.left else: current_node = current_node.right if current_node.value is not None: decoded_text += current_node.value current_node = root return decoded_text # 示例用法 char_freq = {'a': 5, 'b': 9, 'c': 12, 'd': 13, 'e': 16, 'f': 45} huffman_tree = build_huffman_tree(char_freq) huffman_codes = encode_huffman_tree(huffman_tree) encoded_text = ''.join([huffman_codes[char] for char in 'abcdef']) decoded_text = decode_huffman_tree(huffman_tree, encoded_text) print("Huffman Codes:", huffman_codes) print("Encoded Text:", encoded_text) print("Decoded Text:", decoded_text) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值