热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

2018-2019学年第六周《Java数据结构与算法》学习总结

本文总结了2018-2019学年第六周在《Java数据结构与算法》课程中的学习内容,重点介绍了非线性数据结构——树的相关知识及其应用。
### 第六周学习总结:非线性数据结构——树

#### 概述
本周我们深入探讨了第十章的内容,即非线性集合与数据结构——树。树作为一种重要的数据结构,在计算机科学中有着广泛的应用。本章节主要讨论了树的定义、实现方式及实际应用场景。

#### 树的基本概念
树是一种非线性的层次结构,由结点(Node)和边(Edge)组成。以下是树的一些关键术语:

- **根(Root)**:树的顶层唯一结点。
- **孩子(Children)**:位于较低层的结点是上一层结点的孩子。
- **兄弟(Siblings)**:同一双亲的孩子互为兄弟。
- **叶子(Leaf)**:没有孩子的结点。
- **内部结点(Internal Node)**:至少有一个孩子的非根节点。
- **祖先(Ancestor)**:从某一特定结点到根结点路径上的所有结点。
- **子孙(Descendant)**:从根结点到某一特定结点路径上的所有结点。
- **路径长度(Path Length)**:从根结点到该结点的边数。
- **高度(Height)**:从根到最远叶子结点的路径长度。

#### 树的分类
树可以根据其度(Order)进行分类,也可以根据是否平衡进行分类:

- **广义树**:无限制的孩子数目。
- **n元树**:每个结点最多有n个孩子。
- **二叉树**:每个结点最多有两个孩子。
- **平衡树**:所有叶子结点位于同一层或相差不超过一层。
- **完全树**:平衡且底层叶子位于左边。
- **满树**:所有叶子在同一层,每个内部结点有n个孩子。

#### 树的实现方法
树可以通过链式结构或数组实现:

- **链式结构**:使用指针连接各个结点,适合动态变化的树结构。
- **数组实现**:将树元素按特定规则存储在数组中,适用于静态或相对稳定的树结构。

#### 遍历树的方法
遍历树有四种基本方法:

- **前序遍历(Preorder Traversal)**:先访问根结点,再访问左子树,最后访问右子树。
- **中序遍历(Inorder Traversal)**:先访问左子树,再访问根结点,最后访问右子树。
- **后序遍历(Postorder Traversal)**:先访问左子树,再访问右子树,最后访问根结点。
- **层序遍历(Level-order Traversal)**:按层次从上到下逐层访问。

#### 二叉树的应用
表达式树是一种典型的二叉树应用,用于计算后缀表达式。链式结构实现优于数组结构实现,因为链式结构在组合新树时复杂度更低。

#### 学习中的问题及解决

- **问题1**:理解树的数组实现中的模拟链接策略。通过老师的讲解,我明白了这种策略是通过连续分配数组位置来存储树元素,而不是基于树的结构定位。
- **问题2**:理解`ExpressionTreeOp`类中的`termType`变量的作用。这个变量用于区分操作符和操作数,在程序中起到中间值的作用。

#### 代码实现中的挑战

- **问题1**:实现`toString`方法以输出树结构。尝试使用迭代器但未成功,最终未能找到合适的解决方案。
- **问题2**:正确计算树的高度。最初使用了错误的循环逻辑,经过讨论后改为递归查找最远路径。
- **问题3**:运行`BackPainAnalyzer`类时文件找不到。通过添加路径解决了这个问题。

#### 测试活动错题改正

- **问题1**:Java Collections API中索引列表的实现数量。答案选C,但原因尚不明确。
- **问题2**:接口引用可以指向任何实现了该接口的对象。答案选A,正确。

#### 总结
非线性结构的学习标志着我们对更复杂数据结构的理解进一步加深。尽管树结构中仍然存在链表和数组的身影,但我们需要继续努力才能真正融会贯通。

#### 参考资料
- [Java软件结构与数据结构](第四版)
- JavaAPI文档中List的解释
- Java非线性数据结构 树的深刻研究
- Java数据结构-树及树的存储结构
推荐阅读
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 本文介绍如何在 Android 中通过代码模拟用户的点击和滑动操作,包括参数说明、事件生成及处理逻辑。详细解析了视图(View)对象、坐标偏移量以及不同类型的滑动方式。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • 本文详细介绍了Java中的访问器(getter)和修改器(setter),探讨了它们在保护数据完整性、增强代码可维护性方面的重要作用。通过具体示例,展示了如何正确使用这些方法来控制类属性的访问和更新。 ... [详细]
  • 图数据库中的知识表示与推理机制
    本文探讨了图数据库及其技术生态系统在知识表示和推理问题上的应用。通过理解图数据结构,尤其是属性图的特性,可以为复杂的数据关系提供高效且优雅的解决方案。我们将详细介绍属性图的基本概念、对象建模、概念建模以及自动推理的过程,并结合实际代码示例进行说明。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 数组元素逆序排列的实现
    本文介绍了一种简单有效的方法,用于将整数数组中的元素进行逆序排列。通过折半交换对应位置的元素,可以高效地完成这一任务。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
author-avatar
Eva绫波_772
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有