- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
06图PART图的基本表示03无向无权图图的构成顶点 Vertex边 Edge12465图的基本表示——邻接矩阵0123456001010001101000120101010310101004000101050010101601000100312465A[i][j] = 1表示顶点i和顶点j相邻图的基本表示——邻接矩阵790103121623253454560123456001010001101000120101010310101004000101050010101601000100312465程序实现如何将图封装成一个Java类定义成员属性写构造方法测试我们写的类重写toString() 方法在main方法中测试程序实现如何将一张图转换成图类的实例定义成员属性写构造方法测试我们写的类重写toString() 方法在main方法中测试程序实现如何将一张图转换成图类的实例定义成员属性写构造方法测试我们写的类重写toString() 方法在main方法中测试编程实践添加错误处理添加节点验证编程实践V(),E()方法hasEdge方法求相邻节点方法求一个顶点度的方法算法分析空间复杂度 O(V2)时间复杂度: 建图: O(E) 查看两点是否相邻:O(1) 求一个点的相邻节点:O(V)小结采用二维数组的方式,来存储图的信息这节课我们来学习,图,这种数据结构在计算机当中如何表示,如何存储;在上节课,我们说了,图是由 顶点和边来构成的 ,这就和前边学习的线性结构、树状结构不同,图这种结构,不但要存储顶点,还用存储边。再一个,上节课我们也提到,对于图这种结构我们更多的是关心是图中顶点与顶点之间的关系,而不是顶点中的数据,我们使用数字编号来代表顶点。顶点用数字编号来表示,会将很多问题简单化、明了化,那边的信息如何表示,计算机科学家们,在建立这个抽象的数学模型时,采用了数学上称为矩阵,在计算机中称为二维数组的 东东 来表示 图。如果一个图中有N个顶点,那就用一个N * N 的 二维数组,来表示这个图,其中,0到N - 1 表示这N个顶点,数组中的值来表示边的有无,值为1表示有边,为0表示无边,A[0][1]=1,表示顶点 0 和顶点 1 相邻,在顶点0和1之间存在边。 A[2][4]为0,表明顶点2和4之间没有边, 这样左边这张图,就可以用这个二维数组来表示了。这种表示方式称为——邻接矩阵。那下边有一个新的问题,左边这张图,如何转换成右边这个二维数组,最直接的方式就是构造这个二维数组时,直接赋值,但很麻烦,这是一个7 * 7的二维数组,里边的值看的我们就很眼花了乱,那顶点再多一点,麻烦程度可想而知。大多数数据结构的书采用的就是这种方式。今天我们采用一种更偏实际应用的一种方式来进行:首先,将图的信息保存在一个文件中,文件的第一行,有两个数字,第一个数字代表这张图中有多少个顶点,第二个数字代表图中边的个数,后边的每一行,有两个数字,分别代表两个顶点,表示这两个顶点之间有边。在构造这张图的实例时,就可以通过读取文件中的信息,来给这个二维数组赋值了。下边我们就 看看 如何 将这 二维数组 封装成一个表示 图 的java类。?转eclipse 在new这个类时,要从文件中读取图的信息,转存到二维数组中去?转eclipse 在new这个类时,要从文件中读取图的信息,转存到二维数组中去?转eclipse 将 这个图类写的更健壮一些,提高它的容错能力,添加一下容错处理?转eclipse 为这个图 类,提供一些必要的访问接口?转eclipse 简单分析一下 图的 空间复杂度 ,采用二维数组来存放,空间复杂度,顶点的平方时间复杂度,建图时,要在文件中读取每一条边,边的个数是E ,建图算法的时间负责度O(E);查看两个节点是否相邻,直接读取二维数组中的 一个特定值,O(1)就可以了求一个点相邻的节点,需要方法二维数组中 一行,时间复杂度为O(v)邻接矩阵就是采用二维数组的方式来存储图中顶点和边的信息
您可能关注的文档
- 漫话数据结构-舞伴问题.pptx
- 漫话数据结构-学习数据结构的意义.pptx
- 漫话数据结构-深度优先遍历.pptx
- 漫话数据结构-循环队列.pptx
- 漫话数据结构-串的存储及操作.pptx
- 漫话数据结构-顺序队列.ppt
- 漫话数据结构-顺序栈.pptx
- 漫话数据结构-串上的操作.pptx
- 漫话数据结构-顺序查找和折半查找.pptx
- 漫话数据结构-简单选择排序.pptx
- 2026年消防设施操作员之消防设备基础知识考试题库500道带答案(新).docx
- 销售岗前培训课件.ppt
- 2026年消防设备操作员考试题库500道(典型题).docx
- 2026年消防设施操作员之消防设备高级技能考试题库300道附答案(实用).docx
- 2026年消防设施操作员之消防设备高级技能考试题库300道标准卷.docx
- 2026年材料员之材料员基础知识考试题库300道附完整答案(全优).docx
- 2026年材料员之材料员基础知识考试题库300道带答案(培优a卷).docx
- 2026年机械员考试题库含答案(轻巧夺冠).docx
- 2026年材料员之材料员基础知识考试题库300道【夺分金卷】.docx
- 2026年期货从业资格之期货法律法规考试题库500道(考点精练).docx
文档评论(0)