20172315 2018-2019-1 《程序设计与数据结构》第八周学习总结

20172315 2018-2019-1 《程序设计与数据结构》第八周学习总结

教材学习内容总结

  • 堆是一棵完全二叉树,其中的每一结点都小于或等于它的两个孩子。
  • 一个堆也可以是最大堆(maxheap),其中的结点大于或等于它的左右孩子。
  • 最小堆将其最小元素存储在该二又树的根处,且其根的两个孩子同样也是最小堆。
  • addElement方法将给定的Comparable元素添加到堆中的恰当位置处,且维持该堆的完全性属性和有序属性。
  • 因为一个堆就是一棵完全树,所以对于插入的新结点而言,只存在一个正确的位置,且它要么是h层左边的下一个空位置,要么是h+1层左边的第1个位置(如果h层是满的话)。
  • 通常,在堆实现中,我们会对树中的最末一个结点,或更为准确是,最末一片叶子进行跟踪记录。
  • 要维持该树的完全性,那么只有一个能替换根的合法元素,且它是存储在树中最末一片叶子上的元素。
  • 虽然最小堆根本就不是一个队列,但是它却提供了一个高效的优先级队列实现。
  • 因为我们要求在插入元素后能够向上遍历该树,所以堆中结点必须存储指向其双亲的指针。
  • 在二又树的数组实现中,树的根位于位置0处,对于每一结点n,n的左孩子将位于数组的2n+l位置处,n的右孩子将位于数组的2(n+l)位置处。
  • 链表实现和数组实现的addElement操作的时间复杂度同为O(logn)。
  • 链表实现和数组实现的removeMin操作的复杂度同为0(logn)。
  • heapSort方法的两部分构成:添加列表的每个元素,然后一次删除一个元素。
  • 堆排序的复杂度为O(nlogn)。

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

  • 问题1:为什么要维持该树的完全性,那么只有一个能替换根的合法元素,且它是存储在树中最末一片叶子上的元素
  • 问题1解决方案:由于堆是队列结构,只能从堆中删除堆顶元素。移除堆顶元素之后,用堆的最后一个节点填补取走的堆顶元素,并将堆的实际元素个数减1。但用最后一个元素取代堆顶元素之后有可能破坏堆,因此需要将对自顶向下调整,使其满足最大或最小堆。

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

  • 问题1:对于pp12.1说的堆中的比较操作必须依照进入该队列的顺序来进行是什么意思
  • 问题1解决方案:优先级队列把优先级改为一样即可解决

代码托管

(statistics.sh脚本的运行结果截图)

上周考试错题总结

  • 错题1及原因,理解情况

    Insertion sort is an algorithm that sorts a list of values by repetitively putting a particular value into its final, sorted, position.

A . true

B . false

正确答案: B

你的答案: A

insertion sort:插入排序一种排序算法,通过反复地把某个元素插入到之前已排序的子列表中,实现元素的排序。

结对及互评

点评模板:

  • 博客中值得学习的或问题:

    • 对于教材内容解析到位
    • 对于问题探讨不够
  • 代码中值得学习的或问题:
    • 代码简洁,一目了然
    • 代码注释过少

点评过的同学博客和代码

  • 本周结对学习情况

  • 上周博客互评情况

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
目标 5000行 30篇 400小时
第一周 0/0 0/0 0/0
第二周 800/800 2/2 18/18
第三周 600/1400 3/5 22/40
第四周 700/1300 3/8 22/62
第五周 400/1700 3/11 22/84
第六周 200/1900 2/13 20/94
第七周 400/2300 2/15 20/114
第八周 600/2900 2/17 20/134

参考资料

原文地址:https://www.cnblogs.com/huzhitao/p/9938962.html

时间: 2024-10-31 11:23:01

20172315 2018-2019-1 《程序设计与数据结构》第八周学习总结的相关文章

20172315 2018-2019-1 《程序设计与数据结构》第一周学习总结

20172315 2018-2019-1 <程序设计与数据结构>第一周学习总结 教材学习内容总结 第一章 正确性:软件遵守其特定要求的程度. 可靠性:软件故障的频率和重要性. 健壮性:很好地处理错误情况的程度. 可用性:用户可以轻松地在软件中学习和执行任务. 可维护性:可以轻松地对软件进行更改. 可重用性:在开发其他软件系统时可以轻松地重用软件组件. 可移植性:软件组件可以轻松地在多个计算机环境中使用. 运行效率:软件在不浪费资源的情况下实现其目的的程度. 数据结构 程序=数据结构+算法,软件

20172305 2017-2018-2 《程序设计与数据结构》第一周学习总结

20172305 2017-2018-2 <程序设计与数据结构>第一周学习总结 教材学习内容总结 本书的第一章简单的介绍了计算机和JAVA的历史,基础内容很多,代码的讲解还没用正式进入,本周一直在做敲代码的准备,简单敲了老师给的"Hello World!"以及书后的PP1.3.PP1.4等简单的小程序. 教材学习中的问题和解决过程 问题1:三种不同类型的错误,运行错误和逻辑错误的混淆 问题1解决方案:针对EX1.20的"希望做加法时却做里乘法"进行了网上

20172314 2017-2018-2 《程序设计与数据结构》第一周学习总结

20172314 2017-2018-2 <程序设计与数据结构>第一周学习总结 教材学习内容总结 本书第一章为计算机系统概述,前面是一些计算机相关的基础知识,让我对计算机有了一个总体的认识,不再是一片空白了,对主存储器和CPU影响深刻,主存储器用于保存程序和数据,CPU执行程序指令.在接下来的Java编程语言与程序开发部分,开始看的时候有点迷茫,不是很理解,后来先按照作业中附带的流程完成一些代码托管之后,接触了完整的简单的程序之后,再回过头来看书,看到的一些陌生的名词在脑海中就有了实际的对应,

20172317《程序设计与数据结构》第一周学习总结

20172317 2017-2018-2 <程序设计与数据结构>第一周学习总结 教材学习内容总结 重新温习了一遍计算机的基础 总算了解了局域网广域网因特网万维网这些东西之间的区别了 通过URL的例子知道了网址各个部分的含义 对Java编程语言和程序开发有了一个粗浅的了解 教材学习中的问题和解决过程 问题:练习题SR1.13出现了答案与题目不相符的情况 问题解决方案:题中有个选项是"网卡",答案中没有,反而有个题目没有的选项"调制解调器"(俗称"

20172322 2017-2018-2 《程序设计与数据结构》第二周学习总结

20172322 2017-2018-2 <程序设计与数据结构>第二周学习总结 教材学习内容总结 了解了print与println的区别 了解了字符串的拼接可以用+来完成 了解了转义字符的使用 学会了使用赋值 学会使用部分算术运算符 学会了使用Scanner来实现交互性 教材学习中的问题和解决过程 问题1:在最初接触赋值时对foalt和double的赋值范围不了解 问题1解决方案:使用万能的度娘后看到一个高赞答案后有了了解 问题2:在提前预习时看到2.7图形后敲入的代码无法执行 问题2解决方案

20172328《程序设计与数据结构》第二周学习总结

20172328李馨雨<程序设计与数据结构>第二周学习总结 又到周五,李馨雨同学要开始写博客了.让我们开始吧!(????) 教材学习内容总结 1.首先是String类定义的字符串,然后是print和println的区别.转义字符的学习.(让我印象深刻的\b[回车符]在字符串结尾不显示哈哈,及其更新的\t[换行符],还有在课堂上真正明白了什么是回车.) 2.了解变量.常量.赋值语句.变量:保存数据的内存单元.常量:坚定自己不会变的数据!除非你用java的反射(有点复杂,改权限.去修饰符等等.没实

20172327 2017-2018-2 《程序设计与数据结构》第二周学习总结

20172327 2017-2018-2 <程序设计与数据结构>第二周学习总结 教材学习内容总结 字符串的拼接和转义序列的使用 变量的声明和使用 讨论语法及表达式的处理 定义数据转换类型和实现类型转换的机制 创建Scanner类 教材学习中的问题和解决问题 暂无 代码学习中的问题和解决过程 问题1:在提交过程中,突然遇到无法上传的情况 问题2解决方案:通过上网查找,输入git pull之后弹出一个编辑框,选择关闭之后,再次用git push就成功了. 问题2:在按照例题2.10打代码时,Jav

学号20172328《程序设计与数据结构》第九周学习总结

学号20172328<程序设计与数据结构>第九周学习总结 教材学习内容总结(异常和递归) 第11章:异常 1.[异常处理]: 一个异常:是一个定义非正式情况或错误的对象,由程序或者运行时环境抛出,可以根据需要捕获和处理. 错误:错误类似于异常,但是错误代表不可恢复的问题并且必须捕获处理. 2.[处理异常的三种方法]:①根本不处理异常②当异常发生时处理异常③在程序的某个位置集中处理异常. 3.[未捕获的异常]:如果程序中不处理异常,则程序将非正常的终止运行,并产生关于描述在何处发生什么异常的信息

20172326 《程序设计与数据结构》第九周学习总结

学号 20172326 <程序设计与数据结构>第九周学习总结 教材学习内容总结 异常(exception):定义非正常情况下或错误的情况的对象,由程序或运行时环境抛出,可根据需要进行相应的捕获处理. 异常与错误的区别:错误代表不可恢复的问题并且必须捕获处理.而异常可以忽视,或者使用try语句处理,或调用更高级的方法. 可检测异常与不可检测异常:可检测异常必须由方法捕获,或者必须在可能抛出或传递异常方法的throws子句中列出来.在方法定义的声明头中追加一条throws子句.不可检测异常不需要使

20172322 2017-2018-2 《程序设计与数据结构》第九周学习总结

20172322 2017-2018-2 <程序设计与数据结构>第九周学习总结 教材学习内容总结 异常 学会了使用try-catch来实现未捕获的异常的处理.可以使得异常被捕获进而不导致程序出现错误退出.使用try写入可能产生异常的语句,使用catch来编写在捕获异常后继续执行的代码(可以为空). "未捕获的异常"指在编译过程中不会被编译软件显示异常但是在运行时会出现异常导致程序直接退出,例如:"ArithmeticException"."In