板子(匈牙利算法,邻接矩阵) const int MAXN=2e3+5; int uN, vN; int g[MAXN][MAXN]; int linker[MAXN]; bool used[MAXN]; bool dfs(int u) { for(int v=0; v<vN; v++) if(g[ ...
分类:
其他好文 时间:
2019-08-13 09:16:04
阅读次数:
99
第41棵 - 图的存储结构 1. 邻接矩阵法 用一维数组存储顶点--描述顶点相关的数据。 用二维数组存储边--描述顶点的边。 设图A = (V,E)是一个有n个顶点的图,图的邻接矩阵为Edge[n][n],则:Edge[i][j] = W,W>0,i和j连接;Edge[i][j] = 0,i == ...
分类:
其他好文 时间:
2019-08-11 19:00:58
阅读次数:
92
1 作用:对于一张图求生成树数量 矩阵树定理可解决。 2 实现方式 A为邻接矩阵表示两点之间的连接关系 D为度数矩阵存放每个点的度数 根据矩阵的初等变换 基尔霍夫矩阵=D-A; 当然基尔霍夫矩阵就是拉普拉斯矩阵。 有如下几个性质:拉普拉斯矩阵的行列式为0. 拉普拉斯矩阵的任意一个余子式的行列式相等。 ...
分类:
其他好文 时间:
2019-08-09 13:58:24
阅读次数:
115
有这样一道编程面试题,给一个有向图的邻接矩阵,判别它是否有环。 题目麻烦在给的邻接矩阵是以 ‘字符输入流’ 的形式给出的,所以将其处理成数字形式的是首先要做的工作。 得到邻接矩阵之后,进行拓扑排序即可。假如能完成拓扑排序那就无环,如果不能,那就是有环。 样例输入: [[0, 1, 0], [0, 0 ...
分类:
其他好文 时间:
2019-07-30 21:48:13
阅读次数:
111
题意简述 给你一个$n$个节点的无向图$G=\{V,E\}$的邻接矩阵$g$和每个点的点权为$s_i$,且$\sum_{i=1}^n s_i = K$,要你求出$\mathrm{max} \{ \sum_{u,v \in E} s_u \times s_v\}$ 做法 设两个不相邻的点$u$,$v$ ...
分类:
编程语言 时间:
2019-07-06 17:34:18
阅读次数:
190
typedef char DType typedef int BType; #define maxsize 100 #define inifinity 65535 typedef struct { DType v[maxsize];//顶点表 BType a[maxsize][maxsize];//... ...
分类:
其他好文 时间:
2019-06-29 18:54:51
阅读次数:
73
【算法总结】图论-最短路径 一、概念 最短路径问题。即寻找图中某两个特定结点间最短的路径长度。所谓图上的路径,即从图中一个起始结点到一个终止结点途中经过的所有结点序列,路径的长度即所经过的边权和。 二、Floyd算法 用邻接矩阵保存原图,那么此时邻接矩阵中 edge[i][j]的值即表示从结点 i ...
分类:
编程语言 时间:
2019-06-26 13:38:20
阅读次数:
249
图的存储形式有两种: 顺序结构:二维数组———邻接矩阵 链式结构:链表———邻接表 邻接矩阵: 邻接表: ...
分类:
其他好文 时间:
2019-06-16 16:23:25
阅读次数:
118
一、基于邻接矩阵表示法的无向图 邻接矩阵是一种利用一维数组记录点集信息、二维数组记录边集信息来表示图的表示法,因此我们可以将图抽象成一个类,点集信息和边集信息抽象成类的属性,就可以在Java中描述出来,代码如下: 每一个具体的图,就是该类的一个实例化对象,因此我们可以在构造函数中实现图的创建,代码如 ...
分类:
编程语言 时间:
2019-06-09 13:15:45
阅读次数:
117
DFS搜索是搜索中的一种,即深度优先搜索(Depth First Search),其过程简要来说是对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次。图示: 如图,这是邻接矩阵,我们要从s走到e,且“*”不能走,求所有方案。 首先,从s出发,标记s 然后通过s只能走到下面一个点,重 ...
分类:
其他好文 时间:
2019-06-09 12:53:51
阅读次数:
69