# Kirchhoff's theorem. Finding the number of spanning trees

Problem: You are given a connected undirected graph (with possible multiple edges) represented using an adjacency matrix. Find the number of different spanning trees of this graph.

The following formula was proven by Kirchhoff in 1847.

## Kirchhoff's matrix tree theorem

Let \(A\) be the adjacency matrix of the graph: \(A_{u,v}\) is the number of edges between \(u\) and \(v\).
Let \(D\) be the degree matrix of the graph: a diagonal matrix with \(D_{u,u}\) being the degree of vertex \(u\) (including multiple edges and loops - edges which connect vertex \(u\) with itself).

The Laplacian matrix of the graph is defined as \(L = D - A\).
According to Kirchhoff's theorem, all cofactors of this matrix are equal to each other, and they are equal to the number of spanning trees of the graph.
The \((i,j)\) cofactor of a matrix is the product of \((-1)^{i + j}\) with the determinant of the matrix that you get after removing the \(i\)-th row and \(j\)-th column.
So you can, for example, delete the last row and last column of the matrix \(L\), and the absolute value of the determinant of the resulting matrix will give you the number of spanning trees.

The determinant of the matrix can be found in \(O(N^3)\) by using the Gaussian method.

The proof of this theorem is quite difficult and is not presented here; for an outline of the proof and variations of the theorem for graphs without multiple edges and for directed graphs refer to Wikipedia.

## Relation to Kirchhoff's circuit laws

Kirchhoff's matrix tree theorem and Kirchhoff's laws for electrical circuit are related in a beautiful way. It is possible to show (using Ohm's law and Kirchhoff's first law) that resistance \(R_{ij}\) between two points of the circuit \(i\) and \(j\) is

\[
R_{ij} = \frac{ \left| L^{(i,j)} \right| }{ | L^j | }.
\]

Here the matrix \(L\) is obtained from the matrix of inverse resistances \(A\) (\(A_{i,j}\) is inverse of the resistance of the conductor between points \(i\) and \(j\)) using the procedure described in Kirchhoff's matrix tree theorem.
\(T^j\) is the matrix with row and column \(j\) removed, \(T^{(i,j)}\) is the matrix with two rows and two columns \(i\) and \(j\) removed.

Kirchhoff's theorem gives this formula geometric meaning.

## Practice Problems