哈夫曼编码与解码,基于Python实现

news2025/1/24 5:26:57
from itertools import count
from collections import Counter
from heapq import heapify, heappush, heappop

def huffman_tree(s):
    # 统计每个字符出现的次数
    s = Counter(s)                                      # 计算可迭代序列中元素的数量,返回字典类型数据
    chs, freqs = s.keys(), s.values()
    nums = count()                                      # 创建一个从start=0开始的无限迭代器,每次迭代加上step=1
    # 构造堆
    tree = list(zip(freqs, nums, chs))                  # 创建列表,列表中每项为一个三元组(fregs:出现频率,nums:序号,chs:字符名)
    heapify(tree)                                       # 基于tree列表,构建堆
    # 合并结点,构造哈夫曼树
    while len(tree)>1:
        fa, _, a = heappop(tree)                        # 从堆中弹出并返回最小的元素,保持堆属性
        fb, _, b = heappop(tree)
        heappush(tree, (fa + fb, next(nums), [a,b]))    # 将一个元素压入堆中,保持堆属性
    print('='*30)
    print(tree)
    print('='*30)
      
    return tree[0][2]                                   # tree为列表,tree[0][0]堆顶元素和,tree[0][1]:结点序号,tree[0][2]:字符化的树结构
                                                        # tree = [(36, 20, [[['r', 'e'], [['d', 'f'], ['j', 'w']]], ['a', [[['s', 'g'], 'c'], 'b']]])]
    
def get_table(tree, prefix=''):                         # tree:待编码子树,prefix:编码前已确定的树前哈夫曼编码
    # 遍历哈夫曼树,为每个字符编码
    if isinstance(tree, str):
        yield (tree, prefix)                            # yield:返回生成器
        return
    for bit, child in zip('01', tree):
        for pair in get_table(child, prefix+bit):
            yield pair
            
def main(s):
    print(s)
    tree = huffman_tree(s)
    print('='*50)
    gener_test = get_table(tree)
    for item in gener_test:
        print(item)
    print('='*50)
    table = dict(get_table(tree))                       # 单个get_table返回的的是一个生成器。每个生成器的内容为('字符名称','字符对应的哈夫曼编码')
    print(table)
    # 根据哈夫曼编码表对字符串进行编码
    code = ''.join(map(lambda ch: table[ch],s))         # s字符串的更换为哈夫曼编码后,以空格分割
    print(code)
    # 根据哈夫曼编码表进行解码
    code = '0101101101001'                              # 此处可以输入待解码的哈夫曼编码
    ss = ''
    while len(code) > 0:
        for ch, c in table.items():
            if code.startswith(c):
                ss = ss + ch
                code = code[len(c):]                    # code右移,移出已匹配的编码
    print()
    print(ss)
    
main('baaabbcbbbcdcdfsraejajgfweraawaearaa')

引用位置(不带注释):Python实现哈夫曼编码与解码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1176731.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023年09月 Python(三级)真题解析#中国电子学会#全国青少年软件编程等级考试

Python等级考试(1~6级)全部真题・点这里 一、单选题(共25题,每题2分,共50分) 第1题 有一组数据存在列表中,things[“桌子”,“椅子”,“茶几”,“沙发”,“西瓜”,“苹果”,“草莓”,“香蕉”]&#xff0…

Python如何实现查看WiFi密码?

由于最近公司加强对无线安全的管理,wifi密码从以前的12345678,变成复杂难记的一串,导致我时常忘记WIFI密码,而遭受同事的“毒打”。由于我不是那种喜欢打扰同事认真工作的人,于是,我决定用python来试试&…

【Spring】注解

文章目录 1. 前言2.注解开发的准备工作3. IOC相关注解DI相关注解 4. DI相关注解4.1 Value4.2 AutoWired4.3 Qualifier 5. xml配置文件相关注解5.1 Configuration5.2 ComponensScan 6.Bean注解7. PropertySource 1. 前言 Spring支持使用注解代替xml配置,注解开发可以简化配置. …

如何备战秋季招聘:从规划到面试的全方位攻略

如何备战秋季招聘:从规划到面试的全方位攻略 随着秋天的到来,秋季招聘也进入了高峰期。对于即将毕业的同学们来说,抓住这个黄金时期,找到一份满意的工作至关重要。本文将为你提供一份全面的秋季招聘攻略,从规划到面试&…

<微信小程序>《微信小程序开发笔记》(二)

《微信小程序开发笔记》(二) 1 程序开发1.1 原则(自己感悟)1.2 架构1.3 开发模式 2 建立项目3 微信代码构成3.1 JSON 配置文件3.2 WXML 模板文件3.3 WXSS 样式文件3.4 JS 脚本逻辑文件 1 程序开发 1.1 原则(自己感悟&…

吴翰清《计算》重磅来袭,为了可计算的价值,写给所有人!

《计算》终于出版了 计算,为了可计算的价值 撰文 | 吴翰清 三年前在新冠疫情大爆发期间,当我决心动笔写下第一行文字时,从来没想到过写作《计算》的工程会如此之大。 它横跨了人类文明三千年的数学史和计算机科学史,从数字的起…

【JMeter】定时器分类以及场景介绍

1. 定时器分类 固定定时器 作用:请求之间设置等待时间应用场景:查询商品列表后,去查看列表商品详情页。针对商品列表数据量比较大的,响应时间会比较长,就需要设置等待时间然后去查看商详 2.定时器的作用域&#xff1…

《005.SpringBoot+vue之学生选课管理系统01》

《005.SpringBootvue之学生选课管理系统01》 项目简介 [1]本系统涉及到的技术主要如下: 推荐环境配置:DEA jdk1.8 Maven MySQL 前后端分离; 后台:SpringBootMybatis; 前台:vueElementUI; [2]功能模块展示: 管理端 1…

渗透测试学习day1

文章目录 学习平台Starting Point靶机:Meow连接vpn创建靶机 解题过程Task 1Task 2Task 3Task 4Task 5Task 6Task 7Task 8 总结 学习平台 hackthebox Starting Point 靶机:Meow 难度:very easy 连接vpn创建靶机 步骤如下 打开linux虚拟…

开发环境eclipse的安装与配置详细教程(包括UML插件 如何汉化 JDK 代码补全等)

Eclipse开发环境的安装与配置 1.Eclipse安装与配置 1.将JDK与Eclipse这两个软件安装包放在一个文件夹下,方便之后安装使用。 2.安装JDK 在D:LeStoreDownload\java文件夹下另外新建三个文件夹分别命名为java、jdk和eclipse(分别用于Java、j…

NFTScan | 10.30~11.05 NFT 市场热点汇总

欢迎来到由 NFT 基础设施 NFTScan 出品的 NFT 生态热点事件每周汇总。 周期:2023.10.30~ 2023.11.05 NFT Hot News 01/ BAYC 系列 NFT 地板价回升至 30 ETH 10 月 30 日,据数据显示,Bored Ape Yacht Club(BAYC)系列 …

高速串行总线——SATA

SATA简介 SATA的全称是Serial Advanced Technology Attachment(串行高级技术附件,一种基于行业标准的串行硬件驱动器接口),它是一种电脑总线,主要功能是用作主板和大量存储设备(如硬盘及光盘驱动器)之间的数据传输 SA…

没有MES管理系统,先用数据采集设备能有用吗

在当前的数字化时代,企业纷纷意识到了数字化转型的重要性。数据被誉为新型生产要素,对于企业的运营和决策具有至关重要的作用。在数字化转型的过程中,许多企业面临着一个共同的问题:如何获取所需的数据? 有两家企业在…

实力控场,自成焦点!科士达工商业储能新品亮相上海SNEC储能展

11月1日,第八届SNEC ES 国际储能展在上海新国际博览中心盛大开幕。展会现场,科士达携工商业储能新品KAC120DS-BC233DE重磅亮相,该产品是继KAC50DP-BC100DE之后,科士达推出的又一重量级储能力作,完美覆盖用户侧工商业全…

Filter 和 Listener

Filter 表示过滤器。是JavaWeb三大组件(Servlet、Filter、Listener)之一。 过滤器可以把对资源的请求 拦截 下来。浏览器可以访问服务器上所有的资源,而在访问到这些资源之前可以使用过滤器拦截下来,也就是说在访问资源之前会先经…

微信小程序里怎么添加砍价活动

随着网络购物的普及,越来越多的消费者开始享受这种方便快捷的购物方式。而在这个大环境下,各种电商活动层出不穷,吸引了众多消费者的关注。而在这些活动中,砍价活动无疑是最受欢迎的一种。今天,我们就来聊一聊如何在小…

centos7 一键安装部署wvp-gb28181-pro

准备工作 下载finalshell工具 好用的shell工具,FinalShell_好用的shell软件-CSDN博客 设置服务器网络 ky10、centos7等linux系统修改网卡ip地址,并设置网卡开机自启_kylin配置ip-CSDN博客 wvp安装部署 上传文件到服务器 选择服务器上存储的路径&#…

Win10电脑更新显示缺少重要的安全和质量修复怎么解决?

在Win10电脑中用户点击更新系统,却收到了“你的设备中缺少重要的安全和质量修复”的提示,导致无法正常完成Win10系统的更新。下面小编给大家带来简单且有效的解决方法,解决后大家就能顺利完成Win10系统的升级,从而满足自己的个性化…

QML查看事件回调函数的参数

背景 QML里面,为事件写回调函数时,参数(形参)总是不确定是哪些。下面方式可以用来获取形参。 方法 方法一 打印控件类型 使用console.log,查看控件类型 MouseArea {id: mouseAreawidth: 100height: 100onPressed: {}…

taro 接入小程序原生语法代码包的配置

标题taro 接入小程序原生语法代码包的配置 1、微信小程序原生语法代码包拷贝到src目录下 2、config/index.js中配置拷贝原生代码包到编译后的目录中,并且增加编译排除原生代码包的配置 3、app.config.js中配置原生代码包路径、插件(建议分包引入&…