首页
技术博客
PHP教程
数据库技术
前端开发
HTML5
Nginx
php论坛
新用户注册
|
会员登录
PHP教程
技术博客
编程问答
PNG素材
编程语言
前端技术
Android
PHP教程
HTML5教程
数据库
Linux技术
Nginx技术
PHP安全
WebSerer
职场攻略
JavaScript
开放平台
业界资讯
大话程序猿
登录
极速注册
取消
热门标签 | HotTags
dll
heatmap
vbscript
timezone
copy
cPlusPlus
int
window
bash
uri
uml
golang
buffer
datetime
substring
controller
web3
php
bitmap
keyword
select
iostream
perl
format
regex
metadata
frameworks
callback
io
java
javascript
utf-8
subset
jar
eval
plugins
usb
php7
const
triggers
express
range
httpclient
hashcode
jsp
loops
scala
client
cookie
main
instance
erlang
header
schema
expression
python3
blob
case
audio
lua
integer
bit
testing
fetch
search
require
shell
filter
input
join
command
hashset
runtime
foreach
js
tags
email
typescript
httprequest
当前位置:
开发笔记
>
编程语言
> 正文
2018-2019学年第六周《Java数据结构与算法》学习总结
作者:Eva绫波_772 | 来源:互联网 | 2024-12-22 16:43
本文总结了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数据结构-树及树的存储结构
java
编程
io
sum
text
tree
int
数组
rsa
写下你的评论吧 !
吐个槽吧,看都看了
会员登录
|
用户注册
推荐阅读
java
新浪笔试题
1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ...
[详细]
蜡笔小新 2024-12-27 19:32:17
java
Akka BackoffSupervisor的深入解析与实践
本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ...
[详细]
蜡笔小新 2024-12-27 15:04:09
io
XNA 3.0 游戏编程:从 XML 文件加载数据
本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ...
[详细]
蜡笔小新 2024-12-27 11:39:44
io
PHP 5.5.0rc1 发布:深入解析 Zend OPcache
2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ...
[详细]
蜡笔小新 2024-12-26 12:56:20
io
从零构建递归神经网络:仅用NumPy实现
尽管使用TensorFlow和PyTorch等成熟框架可以显著降低实现递归神经网络(RNN)的门槛,但对于初学者来说,理解其底层原理至关重要。本文将引导您使用NumPy从头构建一个用于自然语言处理(NLP)的RNN模型。 ...
[详细]
蜡笔小新 2024-12-26 11:29:15
java
Python 编程进阶:循环结构、函数与面向对象编程
本文深入探讨了 Python 中的循环结构(包括 for 循环和 while 循环)、函数定义与调用,以及面向对象编程的基础概念。通过详细解释和代码示例,帮助读者更好地理解和应用这些核心编程元素。 ...
[详细]
蜡笔小新 2024-12-25 15:48:05
io
深入理解Redis的数据结构与对象系统
本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ...
[详细]
蜡笔小新 2024-12-25 04:11:22
java
Java 序列化接口详解
本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ...
[详细]
蜡笔小新 2024-12-27 15:06:12
io
Unity 客户端框架设计:UI管理系统的构建
本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ...
[详细]
蜡笔小新 2024-12-27 10:28:40
java
寻找满足特定条件的整数N的最大和(a+b)
本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ...
[详细]
蜡笔小新 2024-12-26 19:26:18
io
解析与处理 JSON 中的空数组
本文探讨了如何在编程中正确处理包含空数组的 JSON 对象,提供了详细的代码示例和解决方案。 ...
[详细]
蜡笔小新 2024-12-26 16:33:40
int
DLP数据泄露检测原理浅析
最近团队在部署DLP,作为一个技术人员对于黑盒看不到的地方还是充满了好奇心。多次咨询乙方人员DLP的算法原理是什么,他们都以商业秘密为由避而不谈,不得已只能自己查资料学习,于是有了下面的浅见。身为甲方,虽然不需要开发DLP产品,但是也有必要弄明白DLP基本的原理。俗话说工欲善其事必先利其器,只有在懂这个工具的原理之后才能更加灵活地使用这个工具,即使出现意外情况也能快速排错,越接近底层,越接近真相。根据DLP的实际用途,本文将DLP检测分为2部分,泄露关键字检测和近似重复文档检测。 ...
[详细]
蜡笔小新 2024-12-25 18:19:32
io
毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ...
[详细]
蜡笔小新 2024-12-25 17:38:50
java
在Android中排列多行小部件 - Arranging Rows of Widgets in Android
本文介绍如何使用布局文件在Android应用中排列多行TextView和Button,使其占据屏幕的特定比例,并提供示例代码以帮助理解和实现。 ...
[详细]
蜡笔小新 2024-12-25 10:33:17
java
理解@IfProfileValue:如何检测配置文件的活动状态
本文详细解释了如何使用@IfProfileValue注解来检测Spring框架中的配置文件是否处于活动状态,并探讨其与@Profile和@activeProfiles的区别。 ...
[详细]
蜡笔小新 2024-12-24 16:55:34
Eva绫波_772
这个家伙很懒,什么也没留下!
Tags | 热门标签
dll
heatmap
vbscript
timezone
copy
cPlusPlus
int
window
bash
uri
uml
golang
buffer
datetime
substring
controller
web3
php
bitmap
keyword
select
iostream
perl
format
regex
metadata
frameworks
callback
io
java
RankList | 热门文章
1
快速掌握Sublime Text3的使用方法,怎么汉化编辑器
2
phpcgi参数,phpfastcgi
3
elasticsearch river 参数文档
4
常用的语句
5
oracler日期函数相差六个月_还在人肉处理数据?3个常用表格函数助你效率翻倍,简单易学!...
6
#求200以内的素数和_Python求n以内所有素数 斐波那契 数字字母分离
7
为了小霸王和手柄 我要勇敢而低调的参加魔界村翻唱了
8
华为EMUI8.0支持哪些机型?华为EMUI8.0支持机型一览
9
最新技术_Tungsten Fabric架构和最新技术进展丨TF成立大会演讲实录
10
html滑动门怎么添加,实现滑动门的三种方法_html/css_WEBITnose
11
android 图片读写,Android系统中图片的读写
12
钉钉微应用怎么进入_钉钉微应用的免登录流程
13
二、纯函数、引用透明性和不变性
14
项目管理中,导致进度失控的五种错误
15
屋大维为何没有拜倒在埃及艳后的石榴裙下,难道屋大维是个gay?
PHP1.CN | 中国最专业的PHP中文社区 |
DevBox开发工具箱
|
json解析格式化
|
PHP资讯
|
PHP教程
|
数据库技术
|
服务器技术
|
前端开发技术
|
PHP框架
|
开发工具
|
在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved |
京公网安备 11010802041100号
|
京ICP备19059560号-4
| PHP1.CN 第一PHP社区 版权所有