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

2018201920172321《Java软件结构与数据结构》第六周学习总结

教材学习内容总结

第10章 树

10.1概述

2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

  • 树由一个包含结点和边的集构成,其中的元素被储存在这些结点中,边则将一个结点和另一个结点连接起来。

  • 一棵树只有一个根节点。

  • 树是一种非线性结构,其中的元素被组织成一个层次的结构。

  • 10.1.1树的分类

    • 每一结点限制为不超过n个孩子的树称为一颗n元树。结点最多具有两个的树称为二叉树。
    • 平衡树:如果树的所有叶子都位于同一层或者至少是彼此相差不超过一个层,就称之为是平衡的。

    2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

    • 完全树:如果某树是平衡的,且底层所有叶子都位于shu的左边,则认为该树是完全的。

    2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

    • 满树:如果一颗n元树的所有叶子都位于同一层且每一结点要么是一片叶子要么正好具有n个孩子,则称次树是满的。

    2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

10.2实现树的策略

  • 10.2.1树的数组实现之计算策略
    • 左孩子存储在(2n+1)处,右孩子存储在(2(n+1))处
    • 左孩子存储在(2n+1)处,右孩子存储在(2(n+1))处
  • 10.2.2树的数组实现之计算策略
  • 10.2.3树的分析
    • 一般而言,一棵含有m个元素的平衡n元树具有的高度为lognm

10.3树的遍历

  • 前序遍历:从根节点开始,访问每一结点及其孩子
  • 中序遍历从根节点开始,访问结点的左孩子,然后是该结点,再然后是任何剩余结点
  • 后序遍历:从根节点开始,访问结点的孩子,然后是该结点
  • 层序遍历:从根节点开始,访问每一层的所有结点,一次一层

2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

  • 10.3.1前序遍历
    • A——B——D——E——C——F
  • 10.3.2中序遍历
    • D——B——E——A——F——C
  • 10.3.3后序遍历
    • D——E——B——F——C——A
  • 10.3.4层序遍历
    • A——B——C——D——E——F

10.4二叉树

  • 二叉树的操作
public interface BinaryTreeADT 
{
    //返回指向二叉树的引用
    public T getRootElement();
    //判断该树是否为空
    public boolean isEmpty();
    //判断树中的元素数目
    public int size();
    //判断目标是否在该树中
    public boolean contains(T targetElement);
    //如果找到指定元素,则返回指向其的引用
    public T find(T targetElement);
    //返回树的字符串表示
    public String toString();
    //返回一个迭代器
    public Iterator iterator();
    //为数的中序遍历返回一个迭代器
    public Iterator iteratorInOrder();
    //为数的前序遍历返回一个迭代器
    public Iterator iteratorPreOrder();
    //为数的后序遍历返回一个迭代器
    public Iterator iteratorPostOrder();
    //为数的层序遍历返回一个迭代器
    public Iterator iteratorLevelOrder();
}

10.5使用二叉树:表达式树

  • 算法思想:
    • 依次读取字符。
    • 如果该符号是操作数,创建操作数结点并且入栈。
    • 如果该符号为操作符,把栈顶T1、T2相继出栈,创建操作符结点,操作符结点的左右孩子分别为T1、T2,最后把操作符结点入栈。

10.7用链表实现二叉树

线性结构和非线性结构

  • 线性结构是一个有序数据元素的集合。 其中数据元素之间的关系是一对一的关系,即除了第一个和最后一个数据元素之外,其它数据元素都是首尾相接的。
    常用的线性结构有:线性表,栈,队列,双队列,数组,串。
  • 非线性结构中各个数据元素不再保持在一个线性序列中,每个数据元素可能与零个或者多个其他数据元素发生联系。根据关系的不同,可分为层次结构和群结构。
    常见的非线性结构有:二维数组,多维数组,广义表,树(二叉树等),图。(其中多维数组是由多个一维数组组成的,所以不再是线性结构)

教材学习中的问题和解决过程

  • 问题1:问题2:满二叉树和完全二叉树,概念太扯了吧,不懂在说啥
  • 问题1解决方案:听王老师讲课大概有点感觉。
    • 满二叉树——除了叶结点外每一个结点都有左右子叶且叶子结点都处在最底层的二叉树。
    • 完全二叉树——若设二叉树的高度为h,除第 h 层外,其它各层 (1~h-1) 的结点数都达到最大个数,第h层有叶子结点,并且叶子结点都是从左到右依次排布,这就是完全二叉树。
    • 满二叉树一定是完全二叉树,完全二叉树不一定是满二叉树。
  • 问题2对于树的度,节点的度,树的高度,深度以及节点的层次概念不清楚
  • 问题2解决方案:
    • 节点的度分为0,1,2.及表示节点所含的分支个数,上图中3 的度是 2,10 的度是 1。
    • 树的度分为0,1,2即表示一棵树中最大节点的度,即哪个节点的子节点最多,它的度就是树的度,上图中树的度为 2。
    • 树的高度,即从叶子节点开始,自底向上增加。
    • 树的深度与树的高度相反,从根节点向下增加。比如上图中的 6 ,高度是 2 ,深度是 3。

2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

代码调试中的问题和解决过程

第一次我写了测试,出现了这个恐怖的东西,但是我马上意识到了肯定是我Alt+Enter的时候点到了没有修改过的例题那个类里面,那里的所有方法都是return null或者0的

2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

但是再修改运行之后又是这样

2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

之后我自己改了哪些我都不知道了,然后居然就可以了???可以了??以了?了。

代码托管

2018-2019-20172321 《Java软件结构与数据结构》第六周学习总结

上周考试错题总结

没有测试

结对及互评

  • [20172324曾程](http://www.cnblogs.com/amberR/p/9670328.html)
  • 博客中值得学习的或问题:
    • 内容详略得当;
    • 代码调试环节比较详细;
  • 基于评分标准,我给本博客打分:14分。得分情况如下:
    • 正确使用Markdown语法(加1分)
    • 模板中的要素齐全(加1分)
    • 教材学习中的问题和解决过程, 加4分
    • 代码调试中的问题和解决过程, 加4分
    • 本周有效代码超过300分行,加2分
    • 其他加分,加2分
    • 排版精美的加一分
    • 进度条中记录学习时间与改进情况的加1分

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积)
目标 5000行 30篇 400小时
第一周 0/0 1/1 8/8
第二周 671/671 1/2 17/25
第三周 345/1016 1/3 15/40
第四周 405/1421 2/5 23/63
第五周 1202/2623 1/5 20/83
第六周 1741/4364 1/6 20/103

参考资料

  • 《Java软件结构与数据结构》第四版
  • 完全树-学术百科-知网空间
  • 完美二叉树, 完全二叉树和完满二叉树

推荐阅读
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 本文介绍了Java的集合及其实现类,包括数据结构、抽象类和具体实现类的关系,详细介绍了List接口及其实现类ArrayList的基本操作和特点。文章通过提供相关参考文档和链接,帮助读者更好地理解和使用Java的集合类。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • 本文整理了315道Python基础题目及答案,帮助读者检验学习成果。文章介绍了学习Python的途径、Python与其他编程语言的对比、解释型和编译型编程语言的简述、Python解释器的种类和特点、位和字节的关系、以及至少5个PEP8规范。对于想要检验自己学习成果的读者,这些题目将是一个不错的选择。请注意,答案在视频中,本文不提供答案。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 如何使用计算机控制遥控车的步骤和电路制作方法
    本文介绍了使用计算机控制遥控车的步骤和电路制作方法。首先,需要检查发送器的连接器和跳线,以确定命令的传递方式。然后,通过连接跳线和地面,将发送器与电池的负极连接,以实现遥控车的前进。接下来,制作一个简单的电路,使用Arduino命令将连接到跳线的电线接地,从而实现将Arduino命令转化为发送器命令。最后,通过焊接晶体管和电阻,完成电路制作。详细的步骤和材料使用方法将在正文中介绍。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • Android工程师面试准备及设计模式使用场景
    本文介绍了Android工程师面试准备的经验,包括面试流程和重点准备内容。同时,还介绍了建造者模式的使用场景,以及在Android开发中的具体应用。 ... [详细]
  • 重入锁(ReentrantLock)学习及实现原理
    本文介绍了重入锁(ReentrantLock)的学习及实现原理。在学习synchronized的基础上,重入锁提供了更多的灵活性和功能。文章详细介绍了重入锁的特性、使用方法和实现原理,并提供了类图和测试代码供读者参考。重入锁支持重入和公平与非公平两种实现方式,通过对比和分析,读者可以更好地理解和应用重入锁。 ... [详细]
  • 一、什么是闭包?有什么作用什么是闭包闭包是定义在一个函数内部的函数,它可以访问父级函数的内部变量。当一个闭包被创建时,会关联一个作用域—— ... [详细]
author-avatar
琦琦蔡外_734
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有