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

教材学习内容概要


队列是先进先出(FIFO)的集合

队列是保存重复编码k值的一种有效结构

实现模拟时常用队列来表示等待的一列

队列的链式实现方式便于找到指向链表中的第一个和最后一个元素的引用

入队和出队操作在集合的两端进行

因为队列修改集合的两端,所以将一端固定在下标为0的位置就会让元素移动

非循环数组实现队列时元素的移动得到O(n)阶复杂度

采用数组实现队列时,把数组看成一个环,可以避免移动元素

队列(Queue)是只允许在一端进行插入工作,而在另一端进行删除操作的线性表。队列是一种先进先出(First In First Out)的线性表,简称FIFO。允许插入的一端称为队尾,允许删除的一端称为队头

队列的抽象数据类型:


ADT 队列(Queue)

  • 一个线性集合、它在一端添加元素,另一端删除元素,一端为对头(front),另一端称为队尾(rear)【入队enqueue是指在队尾添加新元素,出队dequeue是指从对头删除元素,first是检测队头元素】

  • 在非空队列中,front始终指向队头元素,rear始终指向队尾元素的下一个位置。

队列的顺序存储


  • 假设队列有n个元素,则顺序存储的队列需建立一个大于n的数组,并将n个元素存储在数组的前n个单元中,数组下标为0的一端为队头。所谓的插入队列操作,其实是在队尾追加一个元素,不需要移动任何元素,时间复杂度为 O(1) 。和栈不同,队列的出列操作在队头进行,即下标为0的位置,即队列中的所有元素都要向前移动,保证队列的队头在下标为0的位置且不为空,此时的时间复杂度为 O(n) 。

循环队列


  • 头尾相接的顺序存储结构被称为循环队列。数组末尾元素占用后,将尾指针改为指向下标为0的位置,继续插入。

队列的链式存储结构


  • 队列的链式存储结构,其实是线性表的单链表,只不过是只能尾进头出而已,将其简称为链队列。将队头指针指向链队列的头结点,队尾指针指向终端结点。当队列为空时,front和rear均指向头结点。

循环队列与链队列的对比:


  • 时间上,基本操作均为常数时间 O(1) ,不过循环队列事先申请存储空间,且使用期间不释放,而链队列,每次申请和释放结点均会产生时间开销,若入出队频繁,二者还是存在差异的。就空间上来说,循环队列有一固定长度,所以存在空间浪费的情况,虽然链队列不存在这个情况,但会产生空间开销,在可接受范围内,所以空间上链队列要更灵活些。

总而言之,在能确定队列长度最大值的情况下,建议使用循环队列,如果无法预估队列长度时,使用链队列。

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


  • 问题1:何为“假溢出”?为何出队列是一定要全部移动呢?若不限制队列的元素不需要存储在数组的前n个单元,即队头不需再下标为0的位置,这样不是能提高队列出列的性能?

  • 问题1解决方案:询问同学并查阅CSDN博客后,得出如下结论——

    引入两个指针,front指针指向队头元素,rear指针指向队尾指针元素的下移位置,这样当front等于rear时,该队列为空队列。

    假设这个队列的总数不超过5个,但是因为数组末尾元素已经占用,再向后加,就会产生数组越界的错误,可实际上,队列在数组前面的位置还是空闲的,这种情况就是”假溢出”现象。

  • 问题2:空队列时,frontrear,而队列满时,还是frontrear,那如何判断队列是空还是满呢?

  • 问题2解决方案:

第一种方法,设置标志变量,当frontrear且flag0时队列为空,当frontrear且flag1时队列为满;

第二种方法,当frontrear时,队列为空,当队列满是,修改其条件,保留一个元素空间(当队列满是,数组中还有一个空闲单位)。假设队列的最大尺寸为QueueSize,则队列满时的条件为(rear+1)%QueueSizefront。(因为rear可能大于也可能小于font,但它们之间总是相差一个元素空间)

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


  • 问题1:不理解循环数组扩充容量的那一行代码
public void expandCapacity(){
T[] larger = (T[])(new Object[queue.length * 2]);
for (int i = 0; i < queue.length; i++){
larger[i] = queue[(front+i)% queue.length];
}
front = 0;
rear = count;
queue = larger;
}
  • 问题1解决方案:阅读到后一页“数组中已存在的元素必须按它们在相对次序复制到新数组中”就明白了

代码托管


上周考试错题总结


  • 尚未公布答案和解析

本周结对学习情况


  • 20162311
  • 结对学习内容

    - 用循环数组实现队列

其他(感悟、思考等,可选)


  • 这周因为平时早上加晚上的校运会训练,周六当天的比赛,再加上系礼仪的任务,能好好学习完成作业的时间不多,哪怕熬了一整个通宵也没能来得及提交第六周的博客,故在此补上。这两天遇到疑难时,查阅了不少相关博客,感觉通读易懂,一目了然(比书上更加清晰),希望自己在理解的基础上也能写出这样的文字。这周的作业量是真的大,五篇博客外加两个课下测试和几个项目,感觉与其提交粗糙的作业,不如能有适当充足的时间,好好看书,仔细查阅,认真写博客,这样实际学到的东西也更多。

学习进度条


代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
目标 5000行 30篇 400小时
第一周 58/ 1/1 10/10
第二周 8/18
第三周 134/ 3/4 12/ 30
第四周 2/6 12/42
第五&六周 750/ 6595 5/11 24/66
  • 计划学习时间: 12小时

  • 实际学习时间:12小时

  • 改进情况:多思考,多尝试

参考资料


20162325 金立清 S2 W6 C15的更多相关文章

  1. 20162325 金立清 S2 W9 C18

    20162325 2017-2018-2 <程序设计与数据结构>第9周学习总结 教材学习内容概要 堆是一棵完全二叉树,其中每个元素大于等于其所有子结点的值. 向堆中添加一个元素的方法是,首 ...

  2. 20162325 金立清 S2 W7 C16

    20162325 2017-2018-2 <程序设计与数据结构>第7周学习总结 教材学习内容概要 树是非线性结构,其元素组织为一个层次结构 树的度表示树种任意结点的最大子结点数 有m个元素 ...

  3. 20162325 金立清 S2 W5 C14

    20162325 2017-2018-2 <程序设计与数据结构>第5周学习总结 关键内容摘要 集合是收集并组织其他对象的对象 集合中的元素一般由加入集合的次序或元素之间某些固有的关系而组织 ...

  4. 20162325 金立清 S2 W3 C13

    20162325 2017-2018-2 <程序设计与数据结构>第3周学习总结 教材学习内容概要 查找是在一组项内找到指定目标或是确定目标不存在的过程 高效的查找使得比较的次数最少 Com ...

  5. 20162325 金立清 S2 W11 C20

    20162325 2017-2018-2 <程序设计与数据结构>第11周学习总结 教材关键概念摘要 在哈希方法中,元素保存在哈希表中,其在表中的位置由哈希函数确定. 两个元素或关键字映射到 ...

  6. 20162325 金立清 S2 W10 C19

    20162325 2017-2018-2 <程序设计与数据结构>第10周学习总结 认识 线性表和树两类数据结构,线性表中的元素是"一对一"的关系,树中的元素是" ...

  7. 20162325 金立清 S2 W8 C17

    20162325 2017-2018-2 <程序设计与数据结构>第8周学习总结 教材学习内容概要 二叉查找树是一棵二叉树,对于其中的每个结点,左子树上的元素小于父结点的值,而右子树上的元素 ...

  8. 20162325金立清 实验四 Android程序设计 实验报告

    实验四 Android程序设计 实验报告 代码托管地址 码云链接 实验内容 安装使用Android Stuidio Activity测试 UI测试 布局测试 事件处理测试 Android程序设计-1 ...

  9. 2017-2018 第一学期201623班《程序设计与数据结构》-第9&10周作业问题总结

    一.作业内容 第8周作业 http://www.cnblogs.com/rocedu/p/7484252.html#WEEK08 第9周作业 http://www.cnblogs.com/rocedu ...

随机推荐

  1. Vue的keep-alive

    Vue的keep-alive: 简答的做下理解 缓存!页面从某一个页面跳转到另一个页面的时候,需要进行一定的缓存,然后这个时候调用的钩子函数是actived,而在第一次加载的时候,created.ac ...

  2. imperva系统升级遇见的错误(配置文件的导入导出)

    今天心态有点炸了 今天去东兴证券做waf升级.浪费了两天才弄完.把客户都弄得有点急了.好歹原厂的工程师耐心的讲解这才弄完.感谢路哥.... 赶紧总结一下. 事情是这样的.东兴 证券的imperva是v ...

  3. 深入解析Mysql 主从同步延迟原理及解决方案

    MySQL的主从同步是一个很成熟的架构,优点为:①在从服务器可以执行查询工作(即我们常说的读功能),降低主服务器压力;②在从主服务器进行备份,避免备份期间影响主服务器服务;③当主服务器出现问题时,可以 ...

  4. Deep Learning基础--Softmax求导过程

    一.softmax函数 softmax用于多分类过程中,它将多个神经元的输出,映射到(0,1)区间内,可以看成概率来理解,从而来进行多分类! 假设我们有一个数组,V,Vi表示V中的第i个元素,那么这个 ...

  5. 5.Python3标准库-日期和时间

    ''' 不同于int,str,float,Python没有包含对应日期和时间的原生类型,不过提供了3个相应的模块,可以采用多种表示来管理日期和时间值 time模块由底层C库提供与时间相关的函数.它包含 ...

  6. Linux硬链接和软连接的区别与总结

    图示软硬链接的区别 有关硬链接的总结 具有相同inode节点号的多个文件互为硬链接文件: 删除硬链接文件或者删除源文件任意之一,文件实体并未被删除: 只有删除了源文件和所有对应的硬链接文件,文件实体才 ...

  7. IP负载均衡技术

    参考链接:http://www.360doc.com/content/12/1117/19/820209_248442094.shtml

  8. php 面试指南

    https://xianyunyh.gitbooks.io/php-interview/

  9. java基础9 main函数、this、static、super、final、instanceof 关键字

    一.main函数详解 1.public:公共的.权限是最大的,在任何情况都可以访问  原因:为了保证jvm在任何情况下都可以访问到main法2.static:静态,静态可以让jvm调用更方便,不需要用 ...

  10. PHP中的魔术方法和关键字

    PHP中的魔术方法总结 :__construct, __destruct , __call, __callStatic,__get, __set, __isset, __unset , __sleep ...