在图论和计算机科学中,邻接矩阵(英语:adjacency matrix)是一种方阵,用来表示有限图。它的每个元素代表各点之间是否有边相连。
作为特例,简单图的邻接矩阵是(0,1)矩阵并且对角线元素都为0。无向图的邻接矩阵是对称矩阵。图和其邻接矩阵的特征值和特征向量之间的关系是谱图理论的研究对象。
图的关联矩阵需要和邻接矩阵区分。它是图的另一种矩阵表示方式,它的元素表示各个节点-边对是否相关。还有图的度数矩阵,含有每个结点的度数信息。
距离矩阵可算是邻接矩阵的扩展。
定义
阶为的图的邻接矩阵是的。将的顶点标签为。若,,否则。也可以用大于0的值表示边的权值,例如可以用边权值表示一个点到另一个点的距离。[1]
例子
无向图的邻接矩阵计算方法是每条边为对应的单元加上1,而每个自环加上2。这样让某一节点的度数可以通过邻接矩阵的对应行或者列求和得到。
有向图的邻接矩阵可以是不对称的。我们可以定义有向图的邻接矩阵中的某个元素Aij代表:
- 从i指向j的边的数目
- 从j指向i的边的数目
第一种定义广泛用于图论和社会网络分析(如:社会学、政治学、经济学、心理学)。[2]第二种更加常见于其他应用学科(如:动态系统、物理、网络学),这些学科有时用邻接矩阵A表示图上的线性动力。[3]
在第一种定义下,有向图的某个节点的入度可以通过对应的列(column)求和而得,出度可以通过对应的行(row)求和而得。在第二种定义下,入度可以通过对应的行(row)求和而得,出度可以通过对应的列(column)求和而得。
特性
设图的邻接矩阵为,边的取值为1。
- 如果顶点有自我连接产生的自环(loop),则在矩阵的主对角线上会有非零的值;如果没有自环,则主对角线上全部是0。
- 的元素可以表示由顶点到顶点长度为的径的数目。[4]
- 没有有向圈当且仅当可逆。的元素表示由顶点到顶点的所有径的数目。因为:
应用
A、B、C、D四人传球6次,从A开始,最终回到A手里,有多少种传法?
非矩阵解法:
矩阵解法:
邻接矩阵法是比较简单的图论问题建模方法,它以方形二维阵列的形式存储图的数据。它在算法应用中的主要特点包括:
- 各元素的取值与边的输入顺序无关。[1]
- 利用输入数据建图之前,因为不一定每对点之间都有边相连,所以先要执行将所有边的权值设为无效值的初始化步骤。以此法建模有个点和条边的图,其初始化需要的时间复杂度,建图的时间则为。[1]
- 以此法建模有个点和条边的图,其内存空间开销的规模是。[1]
主要缺点包括:
参考资料
Wikiwand in your browser!
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.