20172313 2017-2018-2 《程序设计与数据结构》实验一报告
课程:《程序设计与数据结构》
班级: 1723
姓名: 李楠
学号:20172330
实验教师:王志强
实验日期:2018年11月8日
必修/选修: 必修html
参考教材p212,完成链树LinkedBinaryTree的实现(getRight,contains,toString,preorder,postorder)java
用JUnit或本身编写驱动类对本身实现的LinkedBinaryTree进行测试,提交测试代码运行截图,要全屏,包含本身的学号信息git
课下把代码推送到代码托管平台算法
基于LinkedBinaryTree,实现基于(中序,先序)序列构造惟一一棵二㕚树的功能,好比给出中序HDIBEMJNAFCKGL和后序ABDHIEJMNCFGKL,构造出附图中的树数组
用JUnit或本身编写驱动类对本身实现的功能进行测试,提交测试代码运行截图,要全屏,包含本身的学号信息数据结构
课下把代码推送到代码托管平台函数
本身设计并实现一颗决策树源码分析
提交测试代码运行截图,要全屏,包含本身的学号信息post
课下把代码推送到代码托管平台测试
输入中缀表达式,使用树将中缀表达式转换为后缀表达式,并输出后缀表达式和计算结果(若是没有用树,则为0分)
提交测试代码运行截图,要全屏,包含本身的学号信息
课下把代码推送到代码托管平台
完成PP11.3
提交测试代码运行截图,要全屏,包含本身的学号信息
课下把代码推送到代码托管平台
参考http://www.cnblogs.com/rocedu/p/7483915.html对Java中的红黑树(TreeMap,HashMap)进行源码分析,并在实验报告中体现分析结果。
(C:\Program Files\Java\jdk-11.0.1\lib\src\java.base\java\util)
(https://gitee.com/CS-IMIS-23/linan20172330newterm/blob/master/src/week6/LinkedBinaryTreeTest.java)
TreeMap类
①、红黑树的本质:
Ⅰ. 红黑树本质上是一个二叉查找树(BST),可是它从根到最远叶子的长度不会超过到最近叶子长度的两倍,所以是近似平衡的。
Ⅱ. 红黑树的节点不是黑的就是红的,不会有第三种颜色。
Ⅲ. 树根必须是黑色。
Ⅳ. 叶子所指的空节点必须是黑色。
Ⅴ. 若是某个节点是红色,那么它的两个儿子必须都是黑色。
Ⅵ. 从任意节点出发的全部向下的路径上包含相同个数的黑节点。这个个数咱们称为黑高度Bh。
②、 TreeMap:从API文档中查到:基于红黑树(Red-Black tree)的 NavigableMap 实现。该映射根据其键的天然顺序进行排序,或者根据建立映射时提供的 Comparator 进行排序,具体取决于使用的构造方法。TreeMap的几个重要特色:
Ⅰ.TreeMap内部是使用红黑树结构存储的。
Ⅱ. 一个对象想要成为TreeMap中的key,那么该对象所属的类必须实现Comparable接口,不然抛异常,由于key的寻找是依赖于比较器的实现。
Ⅲ.TreeMap中容许null值做为value,可是不容许null成为key。
TreeMap中于红黑树相关的主要函数有:
红黑树的节点颜色--红色 private static final boolean RED = false; 红黑树的节点颜色--黑色 private static final boolean BLACK = true; 红黑树的节点”对应的类。 static final class Entry<K,V> implements Map.Entry<K,V> { ... }
Entry包含了6个部份内容:key(键)、value(值)、left(左孩子)、right(右孩子)、parent(父节点)、color(颜色)
Entry节点根据key进行排序,Entry节点包含的内容为value。
private void rotateLeft(Entry<K,V> p) { ... }//左旋 private void rotateRight(Entry<K,V> p) { ... }//右旋 public V put(K key, V value) { ... }//插入操做 红黑树执行插入操做以后,要执行“插入修正操做”。 目的是:保红黑树在进行插入节点以后,仍然是一颗红黑树 private void fixAfterInsertion(Entry<K,V> x) { ... }//插入修正操做 private void deleteEntry(Entry<K,V> p) { ... }//删除操做 红黑树执行删除以后,要执行“删除修正操做”。 目的是保证:红黑树删除节点以后,仍然是一颗红黑树//删除修正操做 private void fixAfterDeletion(Entry<K,V> x) { ... }//删除修正操做
HashMap类
①.HashMap类的TreeNode结点
static final class TreeNode<K,V> extends LinkedHashMap.Entry<K,V> { TreeNode<K,V> parent; // red-black tree links TreeNode<K,V> left; TreeNode<K,V> right; TreeNode<K,V> prev; // needed to unlink next upon deletion boolean red; }
其中包括红黑树节点,有父亲、左右孩子、前一个元素的节点,还有个颜色值。
②.另外因为它继承自 LinkedHashMap.Entry ,而 LinkedHashMap.Entry 继承自 HashMap.Node ,所以还有额外的 6 个属性:
//继承 LinkedHashMap.Entry 的 Entry<K,V> before, after; //HashMap.Node 的 final int hash; final K key; V value; Node<K,V> next;
HashMap 中有三个关于红黑树的关键参数:
TREEIFY_THRESHOLD
UNTREEIFY_THRESHOLD
MIN_TREEIFY_CAPACITY
//一个桶的树化阈值 //当桶中元素个数超过这个值时,须要使用红黑树节点替换链表节点 //这个值必须为 8,要否则频繁转换效率也不高 static final int TREEIFY_THRESHOLD = 8; //一个树的链表还原阈值 //当扩容时,桶中元素个数小于这个值,就会把树形的桶元素 还原(切分)为链表结构 //这个值应该比上面那个小,至少为 6,避免频繁转换 static final int UNTREEIFY_THRESHOLD = 6; //哈希表的最小树形化容量 //当哈希表中的容量大于这个值时,表中的桶才能进行树形化 //不然桶内元素太多时会扩容,而不是树形化 //为了不进行扩容、树形化选择的冲突,这个值不能小于 4 * TREEIFY_THRESHOLD static final int MIN_TREEIFY_CAPACITY = 64;
1.当时在作的时候实验5输出时只进行了两步而后开始报错。
1.实验1解决方案
我发如今我输入数字的时候中间的空格是后加入的因此致使识别不了最终报错。
这一次的实验都是关于链表,数组,队列的,有不少基础东西上课没有学会的这一次也获得了补充。
《Java 密码学算法》