第八题、哈夫曼编码大全
题目: 哈夫曼编码大全
描述:
关于哈夫曼树的建立,编码,解码。
输入
第一行输入数字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();}}
}
第八题、哈夫曼编码大全相关推荐
- 题目: 哈夫曼编码大全
描述: 关于哈夫曼树的建立,编码,解码. 输入 第一行输入数字N,代表总共有多少个字符以及权值 第二第三行分别是一行字符串,以及每个字符对应的权值 接下来输入一个数M,表示接下来有M行字符串,要求你对 ...
- 数据结构题:根据所给权值设计相应的哈夫曼树,并设计哈夫曼编码
文章目录 前言 一.涉及到的知识点 二.例题讲解 1.例题1 2.例题2 总结 前言 在数据结构树的这章中,常常有题目,是这样的"给定一组权值-,试设计相应的哈夫曼树",有的还要求 ...
- 哈夫曼编码压缩率计算_考研经验分享(哈工大计算机)
2019.3.13 考研就此告一段落,在这里写下我自己的总结. 本人报考的哈尔滨工业大学深圳,专业是计算机科学与技术. 先说初试,初试我考的是数学一(129),英语一(69),政治(75)和计算机基础 ...
- 哈夫曼编码压缩率计算_西工大计算机仍考801!
计算机学院共招收316名研究生,其中推免104人,共招收统招生212人.其中专硕招收193人,考英二数二! 801考试大纲如下: 题号:801 <计算机专业基础> 考试大纲 注:以下五部分 ...
- 信息论4—无失真信源编码(非延长码,霍夫曼编码)
无失真信源编码 单义可译码 码字非奇异,码字序列非奇异. 单义可译定理--克拉夫不等式 非延长码(即时码,在无失真信源编码中,常采用此码) 延长码:部分码字是其它码字的前缀.100是10的延长码,01 ...
- 哈夫曼编码的非树节点形式实现
哈夫曼编码的非树节点形式实现 楔子 思考过程 于是想自己写一个headq 构建二叉树实在太久了,完全不让看文档,不敢不相信在有限的时间里可以调试成功,于是就想了使用非树的实现方式,就是把手动画的二叉树 ...
- 7-2 哈夫曼编码 (30 分)
2019.12.15更正Best函数样本数据初始化问题并且对代码添加了注释; 2020.11.17更正:题目说明: 原贴发于2019.11.22 注意:本题不是哈夫曼编码裸题,学习哈夫曼编码的同学不要 ...
- 对文件进行哈夫曼编码压缩与译码的C++实现 以及压缩率计算 ——HIT杨朔
哈夫曼编码压缩原理:由于每个字符在内存中都是以ASCII码进行存储,所以每个字符都占用了八个01位,利用哈夫曼树对每个字符进行01编码,根据字符在文章中出现的频率调整01串长度,出现频率高的字符在哈夫 ...
- 图像压缩编码——香农/哈夫曼编码
图像压缩编码--香农/哈夫曼编码 一.信息熵 二.香农-范诺编码 2.1 香农-范诺编码简述 2.2 特例详解 三.哈夫曼编码 3.1 哈夫曼编码简述 3.2 特例详解 四.RGB图像压缩 Endin ...
最新文章
- html语言书写注意事项,CSS命名规范参考及书写注意事项
- python自学平台-自学Python网站推荐 从入门到精通
- app.config 配置多项 配置集合 自定义配置(4) 自动增加配置项到配置文件的两种方法...
- 心得体悟帖---开解语录2
- 公司的API接口被刷了,那是因为你没这样做!
- oracle数据库字符编码utf-8改为ZHS16GBK
- ubuntu下的qt程序移植至ARM开发板
- 如何知道自己的php安装在哪,如何知道安装了哪些PHP扩展
- 指针写字符比较c语言,利用指针进行字符串大小比较出现的问题
- 使用一个插件将Zend Framework应用程序的内容转换为xml
- 常用SQL语句(完整范例)
- win7计算机里没有网络图标,Win7网络图标不见了?找回网络图标的方法
- 【Python】Python第三方库概览
- neural-style风格迁移模型实战
- Java ques: java.sql.SQLException: Can not issue data manipulation statements with executeQuery().
- JAVA日期转换函数(包括:日期、周数的计算)
- 常用网络故障排除命令介绍
- 螃蟹芯片RTL8762之修改蓝牙设备类型
- 【计算机网络 12】5G消息能取代IM,Java理论知识总结
- ThinkPad T61安装win7下的指纹识别软件,解决E7210005问题