当前位置:网站首页>图的基础概念
图的基础概念
2022-08-03 22:01:00 【人不负青山】
图的基本概念
图的定义:
- 一个图是由点集V和边集E组成的,一般记作为 G = <V,E>,一个边连接两个顶点。
- 点集V中包含了所有的顶点,边集E中包含了所有边,点集V为空时称为空图。
- 全部由无向边构成的图称为无向图,由有向边构成的图称为有向图。对于有向图的理解可以理解为单行道。
eg:
![[Pasted image 20220729172945.png]]
- 自环: 边连接的两个点是同一个点。
- 重边:无向图中指在两点之间有多条边(>=2)连接,对于有向图则是在两点之间有多条同方向的边(>=2)连接。( 同方向的多条边)
- 孤点 :没有连接边的点叫孤点。(很少用)
- 简单图: 没有自环与重边的图称为简单图
度数:
- 无向图的度数 :对于无向图中的顶点v,v作为边的端点的次数称为v的度数,记作d(v)。 一个点的度数就是看有几个边与它连接
- 有向图的度数:对于有向图的顶点v,v作为边的起点的次数称为v的出度,记作d+(v);v作为边的终点的次数称为v的入度,记作d-(v);顶点v的度数d(v)=d+(v)+d-(v)。
- 每个图G的最大度为所有定点度数的最大值,记作∆(G);最小度为所有顶点度数的最小值,记作δ(G)。了解,一般不会用到
- 一张图G的多有点的度数和为边数的两倍,有向图所有顶点的出度和等于入度和
完全图和竞赛图
- 完全图(无向图):设G为一个有n个节点的无向简单图,若G中每个顶点都与其余n-1 个顶点有边相连,则称G为n阶无向完全图,简称为 n阶完全图,记做Kn。
- 完全图(有向图):设G为一个有n个结点的有向简单图,若G中每个顶点都有连到其余 n-1 个顶点的边,且都有这些结点连向他的边,则称G为n阶有向完全图
- 竞赛图:基于n阶无向完全图,给每条边任意确定一个方向形成的图称为n阶竞赛图。
> ![[Pasted image 20220729190107.png]]
子图、生成子图
- 子图: 设 G = <V,E>,G’ = <V’,E’> 为两个图(同为无向图或有向图),如果V’⊆ V且 E’ ⊆ E, 则称图G’ 为图G 的子图, G称为图G’的母图,记作 G’⊆ G。
- 如果V’ = V 或 E’ ⊂ E, 则称G’ 为 G的真子图
![[Pasted image 20220730105337.png]]
补图
- 补图 :设G=<V,E>是一个n阶无向简单图,以V为顶点集,以所有使G成为完全图Kn需要添加的边的集合为边集的图,称为G的补图.
- 图和它的补图顶点集相同;边集顶点交集为空,并集是完全图的边集
- ![[Pasted image 20220730110346.png]]
同构
- 同构定义 :设G和G’是分别具有顶点集V和V’的两个图。如果存在一个双射(一一映射)h:V->V’,满足当且仅当(vi,vj)是G的边时,(h(vi),h(vj))是G’的边,则称G和G’同构
![[Pasted image 20220730110710.png]]
通路、回路、路径和距离
- 对于一个图 G,G 中顶点与边的交替序列v0e1v2e2v2——envn 称为v0到vn的通路,其中v0,vn称为通路的起点和终点,通路中边的条数称为它的长度。在有向图中,要保持边的方向一致。
- 对于一条通路,如果v0 = vn,则称为回路。如果v0 = vn 且其他所有顶点都不相同,则称为环。
- 如果通路中的所有边都不相同,称为迹(所有边只通过一次)。如果通路中的所有顶点都不相同,边也各不相同,则称为路径。(如果点和边都经过一次的话 叫做路径)‘
- 图中连接两点之间最短的路径长度称为距离。
#### 连通性与连通块
- 无向图:
- 连通性 : 设无向图 G = <V,E>,u,v∈V,如果u,v之间存在通路,则称u,v是连通的。对于∀v∈V,v和v自己是连通的。
- 连通图 :对于任意非空无向图 G,若 G 中任意两个顶点都是连通的,则称 G 为连通图。
- 连通块 :对于无向图 G 的一个连通子图H,如果不存在 F 满足 H ⊂ F ⊆ G 且F 为连通图,则称 H 是 G 的一个连通块/连通分量,H 是一个极大连通子图。
- 有向图:
- 连通性:设有向图 G = <V,E>,u,v∈V,如果存在 u 到 v 的通路,则称 u 可达 v。如果u,v相互可达,则称为u,v 连通。
- 强连通: 如果有向图 G 中的顶点两两可达,则称G 为强连通图。
- 强连通块:与无向图的类似,可以定义有向图的强连通/强连通分量。
图的存储——邻接矩阵
- 无向图的邻接矩阵 A : 在简单图中,如果顶点 u 和顶点 v 之间存在一条边,则A[u][v] =A[v][u] = 1;如果没有则 A[u][v] = A[v][u] = 0。 对于有重边的情况,如果顶点 u 和 顶点 v 之间存在 k 条边
- 对于有向图,如果存在一条顶点u 到顶点v 的边,则A[u][v]在原来的基础上加一。
![[Pasted image 20220730164122.png]]
- 0 1 1 0 1 1 0 1 1 0 1 1 0 0 0 0 1 0 0 1 1 0 0 1 0 \begin{matrix} 0&1&1&0&1\\ 1&0&1&1&0\\ 1&1&0&0&0\\ 0&1&0&0&1\\ 1&0&0&1&0\\ \end{matrix} 0 1 1 0 1 10110110000100110010
### 邻接表 - 邻接表:当一张图节点数比较多,使用邻接矩阵储存所需空间过多时,我们会采用邻接表的形式。每个结点下挂一张链表,储存从这个结点连出的边或能够到达的点。
边栏推荐
猜你喜欢
随机推荐
IO thread process -> thread synchronization mutual exclusion mechanism -> day6
LyScript 实现应用层钩子扫描器
函数,递归以及dom简单操作
一文带你了解软件测试是干什么的?薪资高不高?0基础怎么学?
CAS: 773888-45-2_BIOTIN ALKYNE_生物素-炔基
mysql如何将表结构导出到excel
FVCOM三维水动力、水交换、溢油物质扩散及输运数值模拟丨FVCOM模型流域、海洋水环境数值模拟方法
October 2019 Twice SQL Injection
【kali-漏洞扫描】(2.1)Nessus下载安装(上)
决策树、GBDT、XGBOOST树的可视化
2022的七夕,奉上7个精美的表白代码,同时教大家快速改源码自用
[N1CTF 2018]eating_cms
DO280管理和监控OpenShift平台--资源限制
趣链的产品构架
《强化学习周刊》第56期:GraphIRL、REDEEMER & 眼科强化学习的潜在研究
L2-041 插松枝
pikachu Over permission 越权
XSS练习---一次循环和两次循环问题
CAS:1260586-88-6_Biotin-C5-Azide_Biotin-C5-Azide
shell编程基础