题目: 哈夫曼编码大全
描述:
关于哈夫曼树的建立,编码,解码。

输入
第一行输入数字N,代表总共有多少个字符以及权值
第二第三行分别是一行字符串,以及每个字符对应的权值
接下来输入一个数M,表示接下来有M行字符串,要求你对每个字符串进行编码
再输入一个数X,表示接下来有X行编码,要求你对每行编码进行解码

输出
第一行输出所有节点的权重
接下来输出N行,每行以 “a:001”的格式输出每个字符对应的编码
接着输出M行,对输入的字符串的编码结果
最后,输出X行的解码结果
输入样例

6
abcdef
50 10 5 5 20 10
2
abcdef
defabaabbc
2
011001100100110110101101100
1100011000110101100101100

输出样例

50 10 5 5 20 10 10 20 30 50 100
a:0
b:100
c:1100
d:1101
e:111
f:101
010011001101111101
11011111010100001001001100
accbdfadb
cacadacfb

参考:
本题代码请删除所有中文(包括注释),否则编译错误,无法通过

import java.util.*;public class Main {private static class Node{int value, lchild, rchild, parent;}public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();String str = sc.next();Node[] hfm = new Node[2 * n - 1];for (int i = 0; i < n; i++) {hfm[i] = new Node();hfm[i].value = sc.nextInt();}for (int i = 0; i < n - 1; i++) {// l1 记录最小叶节点下标,l2 记录次小叶节点下标int l1 = -1, l2 = -1;for (int j = 0; j < n + i; j++) {if (hfm[j].parent == 0 && (l1 == -1 || hfm[j].value < hfm[l1].value)) {l2 = l1;l1 = j;} else if (hfm[j].parent == 0 && (l2 == -1 || hfm[j].value < hfm[l2].value)) {l2 = j;}}hfm[n + i] = new Node();hfm[n + i].value = hfm[l1].value + hfm[l2].value;hfm[n + i].lchild = l1;hfm[n + i].rchild = l2;hfm[l1].parent = hfm[l2].parent = n + i;}// 输出所有节点权重for (int i = 0; i < 2 * n - 1; i++) {System.out.print(hfm[i].value + " ");}System.out.println();// 对每个字符编码String[] code = new String[n];for (int i = 0; i < n; i++) {StringBuilder sb = new StringBuilder();int child = i, parent = hfm[i].parent;while (parent != 0) {if (hfm[parent].lchild == child) {sb.append('0');} else {sb.append('1');}child = parent;parent = hfm[parent].parent;}code[i] = String.valueOf(sb.reverse());}// 输出字符的编码for (int i = 0; i < n; i++) {System.out.println(str.charAt(i) + ":" + code[i]);}// 对字符串编码int m = sc.nextInt();for (int i = 0; i < m; i++) {String s = sc.next();for (int j = 0; j < s.length(); j++) {int id = str.indexOf(s.charAt(j));System.out.print(code[id]);}System.out.println();}// 对字符串解码int x = sc.nextInt();for (int i = 0; i < x; i++) {String s = sc.next();int now = 0;while (now < s.length()) {for (int j = 0; j < n; j++) {int idx = s.indexOf(code[j], now);if (idx == now) {now += code[j].length();System.out.print(str.charAt(j));break;}}}System.out.println();}}
}

第八题、哈夫曼编码大全相关推荐

  1. 题目: 哈夫曼编码大全

    描述: 关于哈夫曼树的建立,编码,解码. 输入 第一行输入数字N,代表总共有多少个字符以及权值 第二第三行分别是一行字符串,以及每个字符对应的权值 接下来输入一个数M,表示接下来有M行字符串,要求你对 ...

  2. 数据结构题:根据所给权值设计相应的哈夫曼树,并设计哈夫曼编码

    文章目录 前言 一.涉及到的知识点 二.例题讲解 1.例题1 2.例题2 总结 前言 在数据结构树的这章中,常常有题目,是这样的"给定一组权值-,试设计相应的哈夫曼树",有的还要求 ...

  3. 哈夫曼编码压缩率计算_考研经验分享(哈工大计算机)

    2019.3.13 考研就此告一段落,在这里写下我自己的总结. 本人报考的哈尔滨工业大学深圳,专业是计算机科学与技术. 先说初试,初试我考的是数学一(129),英语一(69),政治(75)和计算机基础 ...

  4. 哈夫曼编码压缩率计算_西工大计算机仍考801!

    计算机学院共招收316名研究生,其中推免104人,共招收统招生212人.其中专硕招收193人,考英二数二! 801考试大纲如下: 题号:801 <计算机专业基础> 考试大纲 注:以下五部分 ...

  5. 信息论4—无失真信源编码(非延长码,霍夫曼编码)

    无失真信源编码 单义可译码 码字非奇异,码字序列非奇异. 单义可译定理--克拉夫不等式 非延长码(即时码,在无失真信源编码中,常采用此码) 延长码:部分码字是其它码字的前缀.100是10的延长码,01 ...

  6. 哈夫曼编码的非树节点形式实现

    哈夫曼编码的非树节点形式实现 楔子 思考过程 于是想自己写一个headq 构建二叉树实在太久了,完全不让看文档,不敢不相信在有限的时间里可以调试成功,于是就想了使用非树的实现方式,就是把手动画的二叉树 ...

  7. 7-2 哈夫曼编码 (30 分)

    2019.12.15更正Best函数样本数据初始化问题并且对代码添加了注释; 2020.11.17更正:题目说明: 原贴发于2019.11.22 注意:本题不是哈夫曼编码裸题,学习哈夫曼编码的同学不要 ...

  8. 对文件进行哈夫曼编码压缩与译码的C++实现 以及压缩率计算 ——HIT杨朔

    哈夫曼编码压缩原理:由于每个字符在内存中都是以ASCII码进行存储,所以每个字符都占用了八个01位,利用哈夫曼树对每个字符进行01编码,根据字符在文章中出现的频率调整01串长度,出现频率高的字符在哈夫 ...

  9. 图像压缩编码——香农/哈夫曼编码

    图像压缩编码--香农/哈夫曼编码 一.信息熵 二.香农-范诺编码 2.1 香农-范诺编码简述 2.2 特例详解 三.哈夫曼编码 3.1 哈夫曼编码简述 3.2 特例详解 四.RGB图像压缩 Endin ...

最新文章

  1. html语言书写注意事项,CSS命名规范参考及书写注意事项
  2. python自学平台-自学Python网站推荐 从入门到精通
  3. app.config 配置多项 配置集合 自定义配置(4) 自动增加配置项到配置文件的两种方法...
  4. 心得体悟帖---开解语录2
  5. 公司的API接口被刷了,那是因为你没这样做!
  6. oracle数据库字符编码utf-8改为ZHS16GBK
  7. ubuntu下的qt程序移植至ARM开发板
  8. 如何知道自己的php安装在哪,如何知道安装了哪些PHP扩展
  9. 指针写字符比较c语言,利用指针进行字符串大小比较出现的问题
  10. 使用一个插件将Zend Framework应用程序的内容转换为xml
  11. 常用SQL语句(完整范例)
  12. win7计算机里没有网络图标,Win7网络图标不见了?找回网络图标的方法
  13. 【Python】Python第三方库概览
  14. neural-style风格迁移模型实战
  15. Java ques: java.sql.SQLException: Can not issue data manipulation statements with executeQuery().
  16. JAVA日期转换函数(包括:日期、周数的计算)
  17. 常用网络故障排除命令介绍
  18. 螃蟹芯片RTL8762之修改蓝牙设备类型
  19. 【计算机网络 12】5G消息能取代IM,Java理论知识总结
  20. ThinkPad T61安装win7下的指纹识别软件,解决E7210005问题

热门文章

  1. Gunicorn配置详解
  2. 【大数据入门核心技术-Tez】(四)Tez与Hdfs整合
  3. 【linux】循序渐进学运维-基础篇-修复文件系统实战
  4. 两台服务器公用一个显示器,两台服务器链接一台显示器
  5. laravel 手动创建分页器LengthAwarePaginator
  6. 线性规划python
  7. 免费的PDF在线合并工具,拿走不谢!
  8. 《STL源码剖析》-- stl_deque.h
  9. 基于JAVASE的彩票摇号系统
  10. lsm mysql_一文了解数据库索引:哈希、B-Tree 与 LSM