Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【自考】数据结构第五章图,期末不挂科指南,第9篇

【自考】数据结构第五章图,期末不挂科指南,第9篇

作者头像
梦想橡皮擦
发布于 2020-01-13 09:23:33
发布于 2020-01-13 09:23:33
5560
举报

图的基本概念

首先,你要明确图是什么样子的,就是下面这个样子的

图的定义与术语

有向图和无向图

直接对比图就可以看出来,有向图和无向图的区别了,这个没有什么难的。

有向图和无向图的表示法有略微的区别,注意看 G1有箭头,有向图,表示方法是 V={V~0~,V~1~,V~2~,V~3~} E = {<V~0~,V~1~>,<V~1~,V~2~>,<V~1~,V~0~>,<V~2~,V~0~>,<V~2~,V~3~>} G2无箭头,无向图,表示方法是 V={V~0~,V~1~,V~2~,V~3~} E = {(V~0~,V~1~),(V~1~,V~2~),(V~0~,V~2~),(V~2~,V~3~)}

弧、弧头、弧尾:有向图的边称为弧。无向图叫做边。有序偶对<v,w>表示有向图从v到w的一条弧,v称为弧尾或始点,w称为弧头或终点。

任何两点之间都有边的无向图称为无向完全图。 任何两点之间都有弧的有向图称为有向完全图。

权、带权图:图的边附带数值,这个数值叫权。每条边都带权的图称为带权图。

顶点的度、入度、出度:

  1. 无向图中顶点v的度是与该顶点相关联的边的数目,记为D(v)。
  2. 有向图中,把以顶点v为终点的弧的数目称为v的入度,记为ID(v);把以顶点v为始点的弧的数目称为v的出度,记为OD(v)。有向图顶点v的度为入度和出度之和,即D(v) = ID(v)+ OD(v)。

简单路径、回路、简单回路:序列中顶点不重复出现的路径称为简单路径。第一个顶点和最后一个顶点相同的路径称为回路。除了第一个顶点和最后一个顶点外,其余顶点不重复的回路,称为简单回路或简单环。

下面还有一些需要了解的术语

连通、连通图、连通分量、极大连通子图、强连通、强连通图、强连通分量、生成树、生成森林

如果精力足够,都看看吧

图的存储结构

图的存储结构有很多中,例如 邻接矩阵、邻接表、十字链表和邻接多重表

邻接矩阵

矩阵中标记1,有边,标记0,没有边

注意:无向图的邻接矩阵是一个对称矩阵

带权图的邻接矩阵

邻接矩阵自考/期末考试真题

尝试着,画出无向图吧!

邻接表

邻接表是顺序存储与链式存储相结合的存储方法。

下图中,左侧是无向图,右侧是该无向图的邻接表,注意看,该符号,表示结束,没有连接的顶点了。

有向图及其类似,这个就不在做图扩充

图的遍历

图的遍历是指从图的某个顶点出发,系统地访问图的每个顶点,并且每个顶点只被访问一次。 遍历图的基本方法有两种:深度优先搜索和广度优先搜索。

连通图的深度优先搜索

深度优先,就是往下走,走不动了,返回上一级在走

连通图的广度优先搜索

顺着一个顶点,然后都遍历完。

图的应用

最小生成树的概念

概念:一个图的最小生成树是图所有生成树中权总和最小的生成树

构造最小生成树的Prim算法

每次都找权值最小的

看案例

构造最小生成树的克鲁斯卡尔算法单源最短路径 这两种算法,自己看一下吧。

拓扑排序

  1. AOV网 工程或者某种流程可以分为若干个小的工程或阶段,这些小的工程或阶段就称为活动。 如果以图中的顶点来表示活动,有向边表示活动之间的优先关系,这种用顶点表示活动的有向图称为AOV网。
  1. 拓扑排序 设G=(V,E) 是一个具有n个顶点的有向图,V中顶点的序列v~1~,v~2~,...,v~n~称为一个拓扑序列,当且仅当该顶点序列满足下列条件:若在有向图G中,从顶点v~i~ ~ v~j~ 有一条路径,则在拓扑序列中顶点v~i~必须排在v~j~之前。找到一个有向图的一个拓扑序列的过程称为拓扑排序。完成拓扑排序的前提条件是AOV网中不允许出现回路。

拓扑排序算法的时间复杂度为O(n+e),n是图的顶点个数,e是图的弧的数目。

拓扑排序算法的基本步骤如下:

  1. 图中选择一个入度为0的顶点,输出该顶点
  2. 从图中删除该顶点及相关联的弧,调整被删弧的弧头结点的入度(入度减1);
  3. 重复执行上述两个步骤,直到所有的入度为0

好好理解一下拓扑排序算法吧

自考/数据结构期末考试真题

画图说明步骤 更多图示: https://dwz.cn/r4lCXEuL

拓扑排序不唯一~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-01-10 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
数据结构:图
无论是有向图还是无向图,主要的存储方式都有两种:邻接矩阵和邻接表。前者图的数据顺序存储结构,后者属于图的链接存储结构。
HLee
2021/01/19
2K0
数据结构:图
数据结构学习笔记(图)
一(基本概念) 1.图的定义:图是由顶点的有穷非空集合和顶点之间边的集合组成,通常表示为:G(V,E),其中,G表示一个图,V是图G中顶点的集合,E是图G中边的集合。 2.与线性表、树的比较: (1)线性表中我们把数据元素叫元素,树中将数据元素叫结点,在图中数据元素,我们则称之为顶点。 (2)线性表中可以没有数据元素,称为空表。树中可以没有结点,叫做空树。在图结构中,不允许没有顶点。 (3)线性表中,相邻的数据元素之间具有线性关系,树结构中,相邻两层的结点具有层次关系,而图中,任意两个顶点之间都可能有关系
希希里之海
2018/05/16
8670
期末复习之数据结构 第7章 图
含有n个顶点的无向完全图有多少条边? n×(n-1)/2条边 含有n个顶点的有向完全图有多少条弧? n×(n-1)条边
henu_Newxc03
2021/12/28
6820
期末复习之数据结构 第7章 图
地图导航的幕后英雄:图论如何改变出行?—全程动画可视化数据结构算法之图
盛透侧视攻城狮
2025/03/17
2700
地图导航的幕后英雄:图论如何改变出行?—全程动画可视化数据结构算法之图
图(graph) 原
图是非线性数据结构,是一种较线性结构和树结构更为复杂的数据结构,在图结构中数据元素之间的关系可以是任意的,图中任意两个数据元素之间都可能相关。
云飞扬
2019/03/12
1.9K0
图(graph)
                                                                            原
数据结构 第六章 图
图是由顶点的有穷非空集合和顶点之间边的集合组成,通常表示为: G=(V,E) 其中:G表示一个图,V是图G中顶点的集合,E是图G中顶点之间边的集合。 在线性表中,元素个数可以为零,称为空表; 在树中,结点个数可以为零,称为空树; 在图中,顶点个数不能为零,但可以没有边。
Twcat_tree
2022/11/29
4980
数据结构  第六章  图
【C#数据结构系列】图[通俗易懂]
大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说【C#数据结构系列】图[通俗易懂],希望能够帮助大家进步!!!
Java架构师必看
2022/02/28
1K0
【C#数据结构系列】图[通俗易懂]
[ data ] 数据结构之图结构的要点梳理
图结构是数据元素呈多对多关系,就是任意两个元素存在这样的关系。如果用一个公式来表示就是由顶点集合和顶点之间的关系集合组成的一种数据结构。
GavinUI
2021/10/08
1.1K0
[ data ] 数据结构之图结构的要点梳理
数据结构–图
1.图 图G由顶点集V和关系集E组成,记为:G=(V,E),V是顶点(元素)的有穷非空集,E是两个顶点之间的关系的集合。 若图G任意两顶点a,b之间的关系为有序对,∈E, 则称为从a到b的一条弧/有向边;其中: a是的弧尾,b是的弧头;称该图G是有向图。 若图G的任意两顶点a,b之间的关系为无序对(a,b), 则称(a,b)为无向边(边),称该图G是无向图。 无向图可简称为图。 2.完全图 3.网:带权的图 4.子图:对图 G=(V,E)和G’=(V’,E’), 若V’
用户7267083
2022/12/08
6830
数据结构–图
数据结构【第六章知识小结】
连通图:在无向图G中,若对任何两个顶点 v、u 都存在从v 到 u 的路径,则称G是连通图。
MIKE笔记
2023/03/22
6050
数据结构【第六章知识小结】
图的应用详解-数据结构
关键路径——在AOE-网中有些活动可以并行地进行,所以完成工程的最短时间是从开始点到完成点的最长路径的长度,路径长度最长的路径叫做关键路径(Critical Path)。
黄规速
2022/04/14
6750
图的应用详解-数据结构
【愚公系列】软考中级-软件设计师 020-数据结构(图)
图是一种非线性数据结构,它由节点(也称为顶点)和连接这些节点的边组成。图可以用来表示各种关系和连接,比如网络拓扑、社交网络、地图等等。图的节点可以包含任意类型的数据,而边则表示节点之间的关系。图有两种常见的表示方法:邻接矩阵和邻接表。
愚公搬代码
2024/02/01
3470
【数据结构】图论基础
图(Graph)是离散数学中的一种重要数据结构,用于描述对象(称为顶点,或节点)之间的关系(称为边)。图可以表示各种事物之间的连接关系,比如网络中的路由器、社交网络中的用户、城市之间的道路等。
用户11305458
2024/10/09
1890
【数据结构】图论基础
《大话数据结构》总结第一章 绪论第二章 算法第三章 线性表第四章 栈和队列第五章 字符串第六章 树第七章 图第八章 查找第九章 排序
第一章 绪论 什么是数据结构? 数据结构的定义:数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 第二章 算法 算法的特性:有穷性、确定性、可行性、输入、输出。 什么是好的算法? ----正确性、可读性、健壮性、时间效率高、存储量低 函数的渐近增长:给定两个函数f(n)和g(n),如果存在一个整数N,使得对于所有的n>N,f(n)总是比g(n)大,那么,我们说f(n)的增长渐近快于g(n)。于是我们可以得出一个结论,判断一个算法好不好,我们只通过少量的数据是不能做出准确判断的,如果我们可以
SeanCheney
2018/04/24
1.5K0
《大话数据结构》总结第一章 绪论第二章 算法第三章 线性表第四章 栈和队列第五章 字符串第六章 树第七章 图第八章 查找第九章 排序
数据结构 图
1-1 无向连通图至少有一个顶点的度为1 错误: 无向连通图考点: 1. 每条边连接两个顶点,所有顶点的度之和等于边数的2倍 2.记住两个特殊的无相连通图模型: A: B: 1-2 用邻接表法存储图
Kindear
2018/01/15
1.9K0
数据结构 图
【数据结构】总结面试最常用的55道填空题
树是由n个结点所构成的有限集合,当n=0时,称为空树 树的表示法有4种,分别为:文氏图表示法、凹入图表示法、广义表表示法以及树形表示法 结点的度是指结点所拥有子树的数目 二叉树是一种特殊的树,它的每个结点最多只有两颗子树,并且这两课子树也是二叉树 在一棵二叉树中,若其所有结点或叶结点,或左、右子树都非空,且所有叶结点都在同一层,则称这棵二叉树为满二叉树 在二叉树的第i层上至多有2i个结点(i≥0) 深度为h(h≥0)的二叉树上至多含2h-1个结点 对于任何一棵二叉树,若其叶结点的个数为n0,度为2的结点个数
陶然同学
2023/02/27
5080
数据结构高频面试题-图
图的基础概念图的基础算法1. 图的遍历深度优先搜索遍历(DFS)广度优先搜索遍历(BFS)2. 单源最短路径问题(Dijkstra算法)3. 拓扑排序4. 最小生成树Kruskal算法(加边法)Prim算法(加点法)经典面试题1.克隆图2.课程表II3.网络延迟问题4.除法求值5.最小高度树6.重新安排行程7. 冗余连接
小萌哥
2020/07/20
2.4K0
数据结构之图
基本概念 图(Graph):图(Graph)是一种比线性表和树更为复杂的数据结构。 图结构:是研究数据元素之间的多对多的关系。在这种结构中,任意两个元素之间可能存在关系。即结点之间的关系可以是任意的,图中任意元素之间都可能相关。 图G由两个集合V(顶点Vertex)和E(边Edge)组成,定义为G=(V,E) 线性结构:是研究数据元素之间的一对一关系。在这种结构中,除第一个和最后一个元素外,任何一个元素都有唯一的一个直接前驱和直接后继。 树结构:是研究数据元素之间的一对多的关系。在这种结构中
xiangzhihong
2018/02/05
8600
数据结构之图
为实习准备的数据结构(11)-- 图论算法 集锦
又要画图了。一到这里就莫名其妙的烦,之前写过的图相关博客已经让我都删了,讲的语无伦次。 希望这篇能写好点。
看、未来
2021/09/18
6140
重学数据结构(七、图)
图是一种比线性表和树更为复杂的数据结构。在线性表中,数据元素之间仅有线性关系,每个数据元素只有一个直接前驱和一个直接后继;在树形结构中,数据元素之间有着明显的层次关系,并且每一层中的数据元素可能和下一层中的多个元素(即其孩子结点)相关,但只能和上一层中一个元素(即其双亲结点)相关; 而在图结构中,结点之间的关系可以是任意的,图中任意两个数据元素之间都可能相关。
三分恶
2020/12/01
7730
重学数据结构(七、图)
相关推荐
数据结构:图
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档