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

教材学习内容总结

本章是第十五章,主要介绍了图的概念。
首先我来介绍一下图的基本结构。
从逻辑上讲,图是由边和结点组成的,在我的理解中结点是用于储存信息的,而边则是用来确定各个结点之间的关系
而图又可以分为两类,无向图和有向图。

无向图
无向图是一种边为无需结点对的图。记作(A,B)意味着A与B之间有一条从两个方向都可以有力的连接。在无向图中,边记作(A,,B)和记作(A,B)的含义是完全一样的。
这是书上的话。
我的理解就是无向图就是将各个结点通过边连接,而已连接结点之间可以双向交互。
下面展示了一个无向图
顶点:A,B,C,D
边:(A,B)(A,C)(B,C)(B,D)(C,D)

有向图
有向图有时也称为双向图,它是一种边为有序顶点对的图,这意味着边(A,B)和边(B,A)在有向图中是不同的有向边。
我的理解就是有向图是已连接的点之间只能单向交互(按照事先规定好的方向)。
下面展示了一个有向图
顶点:A,B,C,D
边:(A,B)(A,C)(B,C)(B,D)(C,D)

一些概念

邻接 如果图中的两个顶点之间有一条连接边则称这两个边是邻接的。
邻居 邻接顶点
路径 图中的一系列边,每个边连接两个顶点
自循环/环 连接一个顶点及其自身对的边
完全图 一个无向图拥有最大数目的连通顶点的边
连通 无向图中任意两个顶点之间都存在一条路径,则认为这个无向图是连通的

无向图连通和不连通的例子。、
连通

不连通

有向图连通和不连通的例子。
连通

不连通

网络的概念
网络实际上就是图在实际中的应用,将一些人们需要的信息储存在边中,通过遍历进行比较或者计算,然后得出对人么有用的结果或信息。
下面是两个关于飞机票价的图的应用。
一个无向网络

一个有向网络

对于网络,我们将用一个三元组中包括起始顶点、终止顶点和权重。对于无向网络来说,起始顶点与终止顶点可以互换。但对于有向图来说,必须宝宝韩每个有向连接的三元组。例如上图可以表示为
顶点:Boston、New York、 Philadelphia、Roanoke
边:(Boston,New York,120),(Boston,Philadelphia,195)
(New York,Boston,140),(New York,Philadeohia,225)
(New York,Roanoke,320),(Philadelphia,Boston,219)
(Philadelphia,New York,205),(Roanoke,New York,240)

常用的图算法
遍历:广度优先遍历类似于树的层次遍历,深度优先遍历类似于树的前序遍历
具体的操作我就不再赘言了,过程在书上都有。这里只写一下具体的步骤,来演示一下
下面是一个演示例子。

广度优先就是先遍历9在遍历6,7,8。然后在遍历3,4,5,然后在遍历1。
深度优先就是类似于先序优先
应该是先遍历9,然后按照列表的顺序遍历6,3,1,2,然后再是4,然后是7,5然后是8。

测试连通性
在前面的讨论中,我们定义了图的连通性:如果图中的任意两个顶点之间都存在一条路径,则认为这个图是连通的。
对图的连通性有一种简单的解法,在一个含n个顶点的图中,当且仅当对每个顶点v,从v开始的广度优先遍历的resultList大小都是n,则该图就是流通的。
下面给出两个例子。一个是连通的,一个是非连通的。
可以看出,连通图中任意顶点看是的遍历都经过了四个顶点,而非连通图中则反之。
连通图

非连通

无向连通图的广度优先遍历

起始顶点 广度优先遍历
A A,B,C,D
B B,A,D,C
C C,B,A,D
D D,B,A,C

最小生成树
生成树包括一个图中所有的顶点和部分边,所以对于某些图,它的生成树就是它本身。
给一个例子

起始顶点 广度优先遍历
A A,B,C
B B,A,C
C C,B,A
D D

一棵生成树

最小生成树的定义就是在加权图中所有的生成树中,权重之和最小的哪一个生成树。
下面是一颗最小生成树的例子
网络

最小生成树

判定最短路径

树的实现策略
邻接列表
关于这种实现,我并没有听从书中的内容,因为我觉得老师讲的更加的通俗易懂。老师所讲解的内容,比书上的讲解的内容更加的浅显易懂。
直接上图

实际上这种实现方法还是很好懂的就是在数组中分别存入以每个结点为头结点的链表,然后在分别在链表中存入其邻接结点。
邻接矩阵
说是矩阵实际上利用的是二维数组。然后就近似成一个表格,在表格的第一行和第一列分别写入图中的元素。然后在中间的每个单元中用二元变量来表示两个节点之间的关系。老师还说如果一个图是强联系图那么使用邻接矩阵是合算的,如果一个图是弱联系图,那么使用邻接矩阵就比较占用资源,这种区别在结点数量较少时没有太大的影响,但是数量大时,影响就很明显,比如一百个结点成链表连接,使用邻接列表就会很占用空间。干讲没意思,直接上图。
一个无向图,由于无向图邻接点之间的关系是双向的。所以显示的邻接矩阵是对称的。所以来时说用邻接矩阵来表示无向图实际上只需要画出一半,所以使用的空间比较少。

一个有向图

教材学习中遇见的问题

问题一:一开始我不是很懂那个书上的那个用邻接列表实现图是怎么来确定那带权的图

解决方案:在老师的讲解下我终于明白了一些。实际上链表中储存的结点并不是类似于树中的那个结点而是类似于边结点性质的结点对应每一个不同的指向顺序其对应的权并不相同。正如图中所圈定的部分虽然同样是在有向图中作为被指定单位部分但是由于两者之间的关系不同(边不同),所以两者之间的权就不同,这种邻接表式的表示法链表中的结点更加与表类似而不是与结点类似。

代码调试中的问题和解决方案

就是在编写代码时发现一处错误

解决方案:后来在对之前写过的代码进行排查发现,是LinkedList类没有声明StackADT这个接口。

代码托管

码云链接

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

上周考试错题总结

博客互评

点评过的同学博客和代码

  • 上周博客互评情况
    20172304郭恺郭恺同学能对教材的内容进行合理的总结又能将树中不懂得知识点分析的如此淋漓尽致。
    20172328李馨雨李馨雨同学的博客内容充实,排版美观,条理清晰,是不可多得的博客。

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

    本周学习了图的相关内容,图是一种与实际应用较为贴切的数据结构。也是一种较为复杂的数据结构。在图的学习中总会遇见许多问题。但最后还是能够通过各种帮助来解决。这应该是本学期树中的最后一章内容了,学习过这一章以后,就要开始进入实践了。总感觉时间过得这么快。希望能够在时间中更好的运用所学的技能。解决更多有用的问题。

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
目标 5000行 30篇 400小时
第一周 30/30 1/1 10/10
第二周 766/796 1/2 40/50
第三周 817/1613 1/3 20/70
第四周 1370/3983 2/5 30/100
第五周 1235/5214 1/6 10/110
第六周 1328/6542 1/7 20/130
第七周 1218/7860 1/8 20/150
第八周 585/9445 1/9 20/170
第九周 2002/11447 35/205

参考资料

1.蓝墨云班课
2.java软件结构与数据结构

转载于:https://www.cnblogs.com/15248252144dzx/p/9978504.html

20172304 《程序设计与数据结构》第九周学习总结相关推荐

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

    第九周学习总结 一.学习目标 二叉查找树的理解 二叉查找树的实现 平衡二叉查找树 哈夫曼树的实现 堆的理解 堆的实现 二.学习内容 1.二叉查找树 思路: 二叉查找树与一般二叉树的区别在于,二叉查找树 ...

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

    学号 2017-2018-2 <程序设计与数据结构>第九周学习总结 教材学习内容总结 异常是定义一个非正常情况或错误的对象,由程序或运行时环境抛出. 异常与错误不同,错误代表不可恢复的问题 ...

  3. 20162329张旭升 2016-2017-2 《程序设计与数据结构》第九周学习总结

    20162329张旭升 2016-2017-2 <程序设计与数据结构>第九周学习总结 教材学习内容总结 1.建立数据库连接:我们是通过老师给的XAMPP程序来配置自己的数据库,然后根据教程 ...

  4. 2018-2019-20172329 《Java软件结构与数据结构》第九周学习总结

    2018-2019-20172329 <Java软件结构与数据结构>第九周学习总结 教材学习内容总结 <Java软件结构与数据结构>第十五章-图 一.图及无向图 1.图的相关概 ...

  5. 20155227 2016-2017-2 《Java程序设计》第九周学习总结

    20155227 2016-2017-2 <Java程序设计>第九周学习总结 教材学习内容总结 JDBC简介 JDBC全名Java DataBase Connectivity,是java联 ...

  6. 20175208 《Java程序设计》第九周学习总结

    20175208 2018-2019-2 <Java程序设计>第九周学习总结 一.教材学习内容总结: 第11章 JDBC与MySQL数据库 MySQL数据库管理系统 MySQL数据库管理系 ...

  7. 20175204 张湲祯 2018-2019-2《Java程序设计》第九周学习总结

    20175204 张湲祯 2018-2019-2<Java程序设计>第九周学习总结 教材学习内容总结 -第十一章JDBC和MySQL数据库要点: 1.下载MySQL和客户端管理工具navi ...

  8. 20175202 《Java程序设计》第九周学习总结

    20175202 2018-2019-2 <Java程序设计>第九周学习总结 教材知识点总结 第11章 JDBC与MySQL数据库 MySQL数据库管理系统 MySQL数据库管理系统,简称 ...

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

    20182316胡泊 2019-2020-1 <数据结构与面向对象程序设计>第1周学习总结 教材学习内容总结 简单java程序是有哪些部分组成的 Java程序好的排版布局是怎样的 程序开发 ...

最新文章

  1. 37 个 MySQL 数据库小技巧,不看别后悔!
  2. 发布订阅之fanout
  3. HDU4372(第一类斯特林数)
  4. XSS挑战赛--Writeup(共16题)
  5. Visual Studio Code Vue代码片段 总览
  6. 设计模式的C语言应用-观察者模式-第四章
  7. android渐变效果
  8. [HTML+CSS]电商网站模板
  9. APP推送系统工作原理
  10. 2020-12-20
  11. 萌新谈相机与IMU的标定(转载)
  12. DBA生活篇之休闲:不做宅男!
  13. Nginx 之实现原理
  14. 渗透测试工具网址--自用
  15. 通过idea的Git使主干项目合并到分支中(主干同步到分支)
  16. M1 macOS 无法录制系统声音?SoundFlower后继有BlackHole【macOS系统声音内录】
  17. java判断图中两点是否连通_连通分量(求有几个连通分量+判断是否两点连通+是否为强联通图 相应例子)...
  18. 软件测试条件组合覆盖三角形,软件测试三角形问题(覆盖测试)
  19. oracle段的集合称为,oracle 集合和成员函数 (plsql表也被称为索引表)
  20. 十六进制与字符串的转换

热门文章

  1. 作为一个程序员为什么要写博客?
  2. Java HotSpot VM 命令行参数【官方版】
  3. C# 打印 长字符串自动换行
  4. WPF怎么寻找在ItemTemplate内部的各种控件
  5. ×××视频下载:皮皮影视客户端功能使用
  6. Mp3写入专辑图片(Kotlin)
  7. 深度高能粒子对撞追踪:Kaggle TrackML粒子追踪挑战赛亚军访谈
  8. 区块链用AI和大数据改变行业现状
  9. Nexus.js介绍:一个多线程的JavaScript运行库
  10. 链接被点击的默认行为——带到另一个窗口