基尔霍夫矩阵
基尔霍夫矩阵是用来求解生成树计数、求(权值)和相关题目的利器。 0. 求完全图的生成树数量(Prufer序列) 要说基尔霍夫矩阵,就要从一道题目说起: 给你 $n$,问 $n$ 个节点组成的无向无根树有多少种。 这道题可以用Prufer序列去做。 这里简单说一下Prufer序列的求法: 对于一张无向无根树,重复执行以下操作直到只剩 $2$ 个或更少的点,最后得到的那个序列 $a$ 就是这棵树的Prufer序列: 我们找到此时度为 $1$ 的节点,若有多个,找编号最小的,设找到的节点编号为 $x$。 在 $a$ 的末尾添加:与 $x$ 有连边的那个唯一节点。 删除 $x$。 Prufer序列别看求法非常简单,也没啥容易发现的性质,其实用处很大。 Prufer序列满足一个性质,就是,所有无向无根树,都可以唯一地对应一个Prufer序列;所有Prufer序列都可以唯一地对应一棵树。 所以,这道题就有解了,答案其实就是长为 $n-2$ 的Prufer序列有多少种。 由于Prufer序列的每个元素的值都是从 $1$ 到 $n$ 的,所以答案就是 $n^{n-2}$,显然。 1.1. 求任意无向图的生成树数量(基尔霍夫矩阵) 但如果把题目变化一下,就不能用Prufer序列去求了: 给你一张 $n$ 个节点 $m$ 条边的无向图,问这张图的生成树有多少个。 这题要用基尔霍夫矩阵。 具体地,我们定义 $D$ 矩阵,求法: $ D_{i,j}= \begin{cases} 0 & i \not= j \ \text{deg}(i) & i=j \end{cases} $ 其中,$\text{deg}(i)$ 代表这张图上 $i$ 的度是多少。 ...