`
李媛媛liyuanyuan
  • 浏览: 15389 次
  • 性别: Icon_minigender_2
社区版块
存档分类
最新评论

树小结

阅读更多
1.树的概述
树代表一种非线性的,复杂的二维结构。

2.树的组成
1.根节点
2.叶子节点
3.路径(分支);

3.树中的一些概念:
1.树的深度:
从根节点开始到叶子节点的路径数最多的那一个就是树的深度(树中节点的最大层次值)
2.度:
表示一个父节点有多少个叶子节点。
3.高度:
树的深度加一。

4.二叉树
二叉树是每个节点最多有两个子树的有序树。通常子树被称作“左子树”(left subtree)和“右子树”(right subtree)。

注:二叉树不是树的的特殊情况

5.树与二叉树的区别
二叉树每个父节点最多只能有两个子节点,树可以有无限个子节点
二叉树的左子结点和右子节点是有是有顺序的,但顺序是自己定义的

6.如何实现一个二叉树
1.将数据存储起来,然后对数据排列
2.创建节点:左右节点的数据域+引用(指针域)
3.构建二叉树:
每次取三个节点,根据大小判读谁为父节点谁为左右子节点(按自己想要的顺序)。再把父节点加到剩余数据中重复上述步骤。

7.树的遍历方式:
1前序遍历:先根,再左,最后右
2后序遍历:先左,再右,最后根
3中序遍历:先左,再根,最后右
中序遍历:
//遍历树 
	public void print1(Point root){
		if(root==null){
			return;
		}
		 //递归调用
		print1(root.getChildLift());
		System.out.print(root.getObj());
		print1(root.getChildRight());
		
	}





哈弗曼树

1.哈夫曼树又称最优树,是一类带权路径最短的树。
其中的一些概念
1.节点之间的路径长度:从一个节点到另一个节点的分支数目
2.树的路径长度:从树的根到每一个节点的的路径长度
3.节点的带权路径长度:从该节点到树根之间的路径长度与节点上权值的乘积。
4.树的带权路径长度:树中所有节点的带权路径长度,记作WPL
注:WPL最小的二叉树称为最优二叉树或哈弗曼树。(完全二叉树不一定是最优二叉树)

2.如何构造一棵哈夫曼树
1.用数组将数据保存起来,并从小到大排序(可用优先队列);
2.取出前两个最小的数创建节点,并使之形成一个性的节点为其父节点,再将其父节点添加到队列中去。
3.重复1,2步。最后便可形成一棵哈夫曼树。

3.哈弗曼压缩
哈弗曼压缩是一种无损压缩,压缩比例为3分之2.对应用程序,重要资料等绝不允许丢失的压缩场合,是最好的选择。


哈弗曼压缩的实现:
(1)读入文件,将文件中同一字符出现的频率用数组存储起来,并排序(可用优先队列,取出即移除)。
(2)根据优先队列创建哈弗曼树(哈树中存的是节点,节点中要存取字符的ascii码值和字符出现的频率):取出队列中的两个最小值,形成一个新的节点,再将新的节点添加
           到队列中去,重复上述步骤,便可构建一棵哈弗曼树。
(3)遍历哈弗曼树,获取哈树中每个叶子节点的哈弗曼编码。
(4)写入文件
1.文件信息头
码表长度,码表对应的字符,码表
码表:编码用byte写入,不足8的整数倍的补零。
文件信息不足8的整数倍的也补零。
2.文件内容的写入。

解压就是压缩的逆过程。
简单来说,1.读取文件信息头按自己定义的读取,获取码表。
  2.读取文件内容,将其转换为字符串与码表匹配,获取其对应的字符写入解压文件,需注意最后一个字节,如有补零,舍零后再写入
我觉得压缩想的过程不太难,但写的时候好麻烦。
1.读文件内容
/**
	 * 读取文件内容并将文件中字符出现的次数存储在数组中
	 * 
	 * @throws FileNotFoundException
	 */
	public void Read(String path) throws Exception {

		// 实例化一个输入流对象
		InputStream is = new FileInputStream(path);
		while (is.available() > 0) {
			int t = is.read();
			array[t]++;
			System.out.println(t + "<><><><><><>" + array[t]);
		}
	}

创建哈夫曼树
/**
	 * 利用数组构哈弗曼树
	 */
	public void createTree() {
		// 优先队列
		PriorityQueue<hfmNode> nodeQueue = new PriorityQueue<hfmNode>();
		// 将所有节点都添加到队列中去
		for (int i = 0; i < array.length; i++) {
			if (array[i] != 0) {
				// 创建节点
				hfmNode hfm = new hfmNode(i, array[i]);
				// 加入节点
				nodeQueue.add(hfm);
			}

		}
		// 构建哈弗曼树
		while (nodeQueue.size() > 1) {
			// 获取队列头
			hfmNode min1 = nodeQueue.poll();
			hfmNode min2 = nodeQueue.poll();
			System.out.println(min1.getObj() + "<><>><" + min2.getObj());
			// 构建一个新的节点,使其成为上两个的父节点
			hfmNode result = new hfmNode(0, min1.getObj() + min2.getObj());
			result.setLChild(min1);
			result.setRChild(min2);
			// 加入合并的节点
			nodeQueue.add(result);

		}
		root = nodeQueue.peek();
	}

获取哈弗曼编码
/**
	 * 取得叶子节点的哈弗曼编码
	 * 
	 */
	public void getMB(hfmNode root, String s) {

		// 判断
		if (root.getLChild() == null && root.getRChild() == null) {
			Code hc = new Code();
			hc.node = s;
			hc.lenght = s.length();

			System.out.println("节点" + root.getCount() + "编码" + hc.node + "<>,."
					+ hc.lenght);
			saveCode[root.getCount()] = hc;

		}
		// 判断递归
		if (root.getLChild() != null) {// 如果含有左子树

			getMB(root.getLChild(), s + '0');

		}
		if (root.getRChild() != null) {// 如果含有右子树
			getMB(root.getRChild(), s + '1');
		}

	}

在接下来就是压缩文件文件写入时以int型写入需将01字符串转换为int型
/**
	 * 将写入的内容变成Int型
	 */
	public int changeString(String s) {
		return ((int) s.charAt(0) - 48) * 128 + ((int) s.charAt(1) - 48) * 64
				+ ((int) s.charAt(2) - 48) * 32 + ((int) s.charAt(3) - 48) * 16
				+ ((int) s.charAt(4) - 48) * 8 + ((int) s.charAt(5) - 48) * 4
				+ ((int) s.charAt(6) - 48) * 2 + ((int) s.charAt(7) - 48);
	}


分享到:
评论

相关推荐

    解决动态统计问题的两把利刃---剖析线段树与矩形切割

    ##### 2.7 线段树小结 线段树是一种强大的数据结构,它可以高效地处理区间查询和更新问题。通过引入懒惰更新机制,可以进一步提高效率。 #### 三、矩形切割 矩形切割是一种解决二维空间中区域查询和更新问题的...

    数据结构与算法分析_Java_语言描述

    3.3.2 栈的实现 3.3.3 应用 3.4 队列ADT 3.4.1 队列模型 3.4.2 队列的数组实现 3.4.3 队列的应用 小结 练习 第4章 树 4.1 预备知识 4.1.1 树的实现 4.1.2 树的遍历及应用 4.2 二叉树 4.2.1 实现 ...

    Java数据结构和算法中文第二版(2)

    小结 问题 第2章 数组 Array专题Applet Java中数组的基础知识 将程序划分成类 类接口 Ordered专题applet 有序数组的Java代码 对数 存储对象 大O表示法 为什么不用数组表示一切? 小结 问题 实验 ...

    数据结构与算法分析C描述第三版

     小结   练习   参考文献  第2章 算法分析   2.1 数学基础   2.2 模型   2.3 要分析的问题   2.4 运行时间计算   2.4.1 一个简单的例子   2.4.2 一般法则   2.4.3 最大子序列和问题的解...

    数据结构与算法分析Java语言描述(第二版)

    摊还分析11.1 一个无关的智力问题11.2 二项队列11.3 斜堆11.4 斐波那契堆11.4.1 切除左式堆中的节点11.4.2 二项队列的懒惰合并11.4.3 斐波那契堆操作11.4.4 时间界的证明11.5 伸展树小结练习参考文献第12章 高级...

    Java数据结构和算法中文第二版(1)

    小结 问题 第2章 数组 Array专题Applet Java中数组的基础知识 将程序划分成类 类接口 Ordered专题applet 有序数组的Java代码 对数 存储对象 大O表示法 为什么不用数组表示一切? 小结 问题 实验 ...

    数据结构与算法分析-Java语言描述(第2版)_2_2

    3.6.3 应用 3.7 队列adt 3.7.1 队列模型 3.7.2 队列的数组实现 3.7.3 队列的应用 小结 练习第4章 树 4.1 预备知识 4.1.1 树的实现 4.1.2 树的遍历及应用 4.2 二叉树 4.2.1 实现 4.2.2 例子...

    数据结构与算法分析-Java语言描述(第2版)_1_2

    3.6.3 应用 3.7 队列adt 3.7.1 队列模型 3.7.2 队列的数组实现 3.7.3 队列的应用 小结 练习第4章 树 4.1 预备知识 4.1.1 树的实现 4.1.2 树的遍历及应用 4.2 二叉树 4.2.1 实现 4.2.2 例子...

    数据结构与算法分析_Java语言描述(第2版)]

    摊还分析11.1 一个无关的智力问题11.2 二项队列11.3 斜堆11.4 斐波那契堆11.4.1 切除左式堆中的节点11.4.2 二项队列的懒惰合并11.4.3 斐波那契堆操作11.4.4 时间界的证明11.5 伸展树小结练习参考文献第12章 高级数据...

    数据结构与算法分析 Java语言描述第2版

    摊还分析11.1 一个无关的智力问题11.2 二项队列11.3 斜堆11.4 斐波那契堆11.4.1 切除左式堆中的节点11.4.2 二项队列的懒惰合并11.4.3 斐波那契堆操作11.4.4 时间界的证明11.5 伸展树小结练习参考文献第12章 高级数据...

    [10.6.1]--615树结构小结.srt

    [10.6.1]--615树结构小结.srt

    [10.6.1]--615树结构小结.mp4

    [10.6.1]--615树结构小结.mp4

    Eclipse_Swt_Jface_核心应用_部分19

    9.10.5 树小结 198 9.11 格式化文本(StyleText) 198 9.11.1 格式化对象(StyleRange) 199 9.11.2 格式化文本的事件处理 200 9.11.3 对选中文本设置格式 201 9.11.4 自动为数字字符着色 203 9.11.5 ...

    C++大学教程,一本适合初学者的入门教材(part2)

    小结 术语 自测练习 自测练习答案 练习 第2章 控制结构 2.1 简介 2.2 算法 2.3 伪代码 2.4 控制结构 2.5 if选择结构 2.6 if/e1se选择结构 2.7 while重复结构 2.8 构造算法:实例研究1(计数器控制重复) 2.9 ...

    C++大学教程,一本适合初学者的入门教材(part1)

    小结 术语 自测练习 自测练习答案 练习 第2章 控制结构 2.1 简介 2.2 算法 2.3 伪代码 2.4 控制结构 2.5 if选择结构 2.6 if/e1se选择结构 2.7 while重复结构 2.8 构造算法:实例研究1(计数器控制重复) 2.9 ...

    讲正气树新风学习小结.doc

    【讲正气 树新风】的学习小结主要围绕中华传统美德中的“朴实”展开讨论。在当前社会背景下,物质追求盛行,人们容易忽视道德规范和人格培养,导致价值观的扭曲。作者指出,朴实并不意味着过时,而是代表了一种淳朴...

    B树、B-树、B+树、B树_介绍、比较与小结(转载).doc

    B树、B-树、B+树和B*树是数据库和文件系统中常见的数据结构,主要用于高效地存储和检索大量数据。它们都是自平衡的多路搜索树,能够保持数据的有序性,并且在插入、删除和查找操作时保持较高的效率。 1. **B树**:B...

    Kruskal算法和prim算法求最小生成树学习小结(JAVA)

    最小生成树是图论中的一个重要概念,用于寻找一个无向加权图的边集合,使得这些边连接所有顶点,并且这些边的总权重尽可能小。在这个问题上,Kruskal算法和Prim算法是非常经典的解决方案,它们都是在寻找图的最小...

    jQuery树形控件zTree使用小结

    jQuery树形控件zTree是一款基于jQuery的多功能树形控件插件,它广泛应用于Web开发中,提供了一个方便的方式来实现树状数据结构的展示与管理。zTree具备优异的性能,支持灵活的配置选项,并能够与多种功能组合使用,...

Global site tag (gtag.js) - Google Analytics