20182311 2019-2020-1 《数据结构与面向对象程序设计》第8周学习总结

目录

  • 教材学习内容总结

    • 教材第13章
  • 教材学习中的问题和解决过程
  • 代码调试中的问题和解决过程
  • 代码托管
  • 结对及互评
    • 点评过的同学博客和代码
  • 感悟
  • 学习进度条
  • 参考链接

正文

20182311 2019-2020-1 《数据结构与面向对象程序设计》第8周学习总结

教材学习内容总结

教材第13章

  • 查找

    • 线性查找:改进方法:设立哨兵,即将数组下标为0的内容设定为需要查找的数字,这样可以减少每次循环都对下标与最大值的比较,优化算法。
    • 折半查找:时间复杂度为O(log2n),效率高,但只能用于有序线性存储结构。
    • 哈希表查找:使用mod算法来实现数据的快速存取
      • 冲突:两个不同关键字对应同一个内存地址
      • 开放地址法:线性探测再散列,若关键字对应地址非空,向后移位直到找到空地址存入,查找步骤与之相同。
      • 链地址法:将存储空间定义为链表数组,每一个存储空间都代表一个链表的表头,若出现冲突,直接延长链表的长度,查找顺序与存入顺序相同。
    • 二叉排序树:通过在各个岔路口分流实现数据的排序。在实现过程中我使用了类似双向链表的数据结构,不过链表的两头只用来向下指左右子树,所以做出来的二叉树只能单向的读取数据,不能实现真正的“双向”。
  • 排序
    • 衡量排序算法是否稳定的标准:相同元素排序后先后次序是否发生变化,
    • 插入排序:利用双重循环和插入,逐渐将整个表从前向后实现有序排列。
    • 折半插入排序:对插入排序的改良,将线性探索改为折半探索
    • 希尔排序
    • 快速排序:根任意元素划分表,再递归的对两个子表进行排序,从而完成一整组的排序。
    • 冒泡排序和选择排序
    • 归并排序:先递归的把表对分成每个子表只含一个元素,再将子表按序合并。
    • 基数排序
  • ASL(平均查找性能分析):查找所有元素需要进行的比较次数之和/元素总个数。

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

  • 问题1:==,equals和compareTo的区别?
  • ==:一般比较两个变量的值,返回true和false,比较对象的地址,不比较对象的内容
  • equals:比较两个对象的内容,一般用于比较字符串。
  • compareTo:在API中,java.lang包下面的基本数据类型(Integer,Float,Byte,Short,Character 等)的封装类都实现了对应的compareTo方法。例如对应Interger实现了数值大小判断;对应String按照字典排序实现字符串的判断,返回的是字符串长度差或者是字符间在码表上的差距。compareTo返回int值,大于返回大于0的整数,等于返回0,小于返回小于0的整数。
  • 问题2:comparable不是接口吗,为什么好像当作一种数据类型来使用,声明数组类型?
  • 问题2解决方案:comparable可用于表示实现comparable接口的对象类型。实现了comparable的对象类型,创建的对象数组使用arraysort时也课使用复写的compareTo方法。

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

  • 问题1:使用二叉排序树找不到元素?
  • 问题1解决方案:存入算法出现问题,查找也很繁杂。看了网上的博客后还是选择了递归方法,递归用于有顺序的数据结构的查找很方便。然后我做的二叉树差不多是这么个意思:

代码托管

结对及互评

点评过的同学博客和代码

  • 本周结对学习情况

    • 20182303

感悟

学排序查找算法不去看标准答案,而是自己先思考,虽然花费比别人数倍的时间,但是感觉收获会更多。但是还是感觉自己学的太潦草了...

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
目标 10000行 30篇 400小时
第一周 246/246 2/2 30/30 初步掌握linux命令、java小程序和jdb调试
第二周 73/319 3/3 30/60
第三周 906/1225 3/6 20/80
第四周 748/1973 2/8 20/100
第五周 849/2822 2/10 20/120
第六周 962/ 3784 2/12 30/150
第七周 1883/5668 3/15 50/200
第八周 579/6247 1/16 30/230

参考链接

原文地址:https://www.cnblogs.com/lengchong/p/11789819.html

时间: 2024-11-09 14:46:55

20182311 2019-2020-1 《数据结构与面向对象程序设计》第8周学习总结的相关文章

《数据结构与面向对象程序设计》第四周学习总结

20182304 2019-2020-1 <数据结构与面向对象程序设计>第四周学习总结 教材学习内容总结 1.本章我们学习了使用并编写我们自己的类:类中有与类同名的构造方法,也可以有set,get,toSring与自己定义的方法.实例化一个对象,可通过该对象使用类里的所有方法.实例数据是每次创造一个实例后自动生成新的内存空间的变量 2.uml类图 :每个类可能包含三部分内容:类名.属性.操作(方法).UML类图有属于自己的语法,变量的类型名在变量名的后面,它们之间用冒号作为分隔符,方法的+和-

20182306 2019-2020-1 《数据结构与面向对象程序设计》第五学习总结

20182306 2019-2020-1 <数据结构与面向对象程序设计>第五学习总结 教材学习内容总结 尽量简单的总结一下本周学习内容 尽量不要抄书,浪费时间 看懂就过,看不懂,学习有心得的记一下 教材学习中的问题和解决过程 问题1:XXXXXX 问题1解决方案:XXXXXX 问题2:XXXXXX 问题2解决方案:XXXXXX ... 代码调试中的问题和解决过程 问题1:XXXXXX 问题1解决方案:XXXXXX 问题2:XXXXXX 问题2解决方案:XXXXXX ... 代码托管 (stat

20182335 2019-2020-1 《数据结构与面向对象程序设计》第四周学习总结

教材学习内容总结 1.继承的基本语法与用法. 2.利用UML类图表示继承关系. 3.在具体编写类的时候,先是数据声明再是方法声明. 4.toString方法用println或print或字符串连接会自动调用. 5.每创建一个对象.都会为类中声明的变量建立新的内存空间. 6.UML图一些基础使用方法. 7.对象应该是自管理的,既对象的实例数据应该仅由该对象来修改,这就构成了封装. 代码调试中的问题和解决过程 问题1:测试代码出现错误 问题1解决方案:junit的方法名必须是textxxx或xxxt

20182322 2019-2020-1 《数据结构与面向对象程序设计》第四周学习总结

教材学习内容总结 1.编写类与方法(构造方法的结构和用途) 2.实际参数与形式参数.public与private.return与void的区别与含义. 3.UML类图的含义与形式 4.静态类(Math类)静态变量.静态方法 5.类间关系(依赖关系.聚合关系.继承关系) 6.接口的使用,能够在某个类中实现接口的方法(Comparable.Iterator) 7.软件活动开发.方法设计.方法重载.测试(黑盒测试.白盒测试) 教材学习中的问题和解决过程 问题1:toString与return返回的值的

20182311 2019-2020-1 《数据结构与面向对象程序设计》实验二报告

20182311 2019-2020-1 <数据结构与面向对象程序设计>实验二报告 课程:<程序设计与数据结构> 班级: 1823 姓名: 冷冲 学号:20182311 实验教师:王志强 实验日期:2019年9月16日 必修/选修: 必修 1.实验内容 (1) 编写简单的计算器,完成加减乘除模运算. (2) 要求从键盘输入两个数,使用判定语句选择一种操作,计算结果后输出,然后使用判定和循环语句选择继续计算还是退出. (3) 编写测试代码,测试验证.(https://www.cnbl

20182311 2019-2020-1 《数据结构与面向对象程序设计》实验四报告

20182311 2019-2020-1 <数据结构与面向对象程序设计>实验四报告 课程:<程序设计与数据结构> 班级: 1823 姓名: 冷冲 学号:20182311 实验教师:王志强 实验日期:2019年9月30日 必修/选修: 必修 1.实验内容 (一)Java Socket编程 1.学习蓝墨云上教材<Java和Android编程>"第16章 输入/输出 "和"第22章 网络",学习JavaSocket编程 2.结对编程.结

20182311 2019-2020-1 《数据结构与面向对象程序设计》实验五报告

20182311 2019-2020-1 <数据结构与面向对象程序设计>实验五报告 课程:<程序设计与数据结构> 班级: 1823 姓名: 冷冲 学号:20182311 实验教师:王志强 实验日期:2019年10月16日 必修/选修: 必修 1.实验内容 1.Android Stuidio的安装测试: 参考<Java和Android开发学习指南(第二版)(EPUBIT,Java for Android 2nd)>第二十四章: 参考http://www.cnblogs.c

20182311 2019-2020-1 《数据结构与面向对象程序设计》第4周学习总结

目录 教材学习内容总结 教材4.8.1及第五章 教材学习中的问题和解决过程 代码调试中的问题和解决过程 代码托管 上周考试错题总结 结对及互评 点评过的同学博客和代码 感悟 学习进度条 参考资料 正文 20182311 2019-2020-1 <数据结构与面向对象程序设计>第4周学习总结 教材学习内容总结 教材4.8.1及第五章 迭代器和for循环 类和对象:子类与父类:继承.声明一个类不会分配内存空间,只有实例化对象才会分配空间.目前已知两种调用类的方法,通过实例化的对象调用,静态方法直接使

20182311 2019-2020-1 《数据结构与面向对象程序设计》第7周学习总结

目录 教材学习内容总结 教材第12章 教材第14章 教材第15章 教材学习中的问题和解决过程 代码调试中的问题和解决过程 代码托管 2 结对及互评 点评过的同学博客和代码 感悟 学习进度条 参考资料 正文 20182311 2019-2020-1 <数据结构与面向对象程序设计>第7周学习总结 教材学习内容总结 教材第12章 算法效率可以用问题大小(n)和及处理步骤来定义.增长函数表示问题大小与希望优化的值之间的关系,该函数表示算法的时间或空间利用率. 我们更关心算法的渐进复杂度,用来表示增长函