Adjacency Matrix Example in Java
12.1 AdjacencyMatrix: Representing a Graph by a Matrix
An adjacency matrix is a way of representing an vertex graph
by an
matrix,
, whose entries are boolean values.
int n; boolean[][] a; AdjacencyMatrix(int n0) { n = n0; a = new boolean[n][n]; }
The matrix entry is defined as
In this representation, the operations ,
, and
just involve setting or reading the matrix entry
:
void addEdge(int i, int j) { a[i][j] = true; } void removeEdge(int i, int j) { a[i][j] = false; } boolean hasEdge(int i, int j) { return a[i][j]; }These operations clearly take constant time per operation.
|
Where the adjacency matrix performs poorly is with the and
operations. To implement these, we must scan all
entries in the corresponding row or column of
and gather up all the indices,
, where
, respectively
, is true.
List<Integer> outEdges(int i) { List<Integer> edges = new ArrayList<Integer>(); for (int j = 0; j < n; j++) if (a[i][j]) edges.add(j); return edges; } List<Integer> inEdges(int i) { List<Integer> edges = new ArrayList<Integer>(); for (int j = 0; j < n; j++) if (a[j][i]) edges.add(j); return edges; }These operations clearly take
data:image/s3,"s3://crabby-images/fedb6/fedb63ba0da96addf2ddff49b4271d14b0a9918e" alt="$ O(\ensuremath{\mathtt{n}})$"
Another drawback of the adjacency matrix representation is that it is large. It stores an boolean matrix, so it requires at least
bits of memory. The implementation here uses a matrix of
values so it actually uses on the order of
bytes of memory. A more careful implementation, which packs
boolean values into each word of memory, could reduce this space usage to
words of memory.
Theorem 12..1 The AdjacencyMatrix data structure implements the Graph interface. An AdjacencyMatrix supports the operations
The space used by an AdjacencyMatrix is .
Despite its high memory requirements and poor performance of the and
operations, an AdjacencyMatrix can still be useful for some applications. In particular, when the graph
is dense, i.e., it has close to
edges, then a memory usage of
may be acceptable.
The AdjacencyMatrix data structure is also commonly used because algebraic operations on the matrix can be used to efficiently compute properties of the graph
. This is a topic for a course on algorithms, but we point out one such property here: If we treat the entries of
as integers (1 for
and 0 for
) and multiply
by itself using matrix multiplication then we get the matrix
. Recall, from the definition of matrix multiplication, that
data:image/s3,"s3://crabby-images/7f3c7/7f3c7f81ac198c41853d873ef9c74be6d44b63b8" alt="$ G$"
data:image/s3,"s3://crabby-images/7a64c/7a64cf30dc815c256329a2e11fa1cdeb78a12902" alt="$ \ensuremath{\mathtt{k}}$"
data:image/s3,"s3://crabby-images/0e18e/0e18e63058c5af85ef4538da5389086e99a1c17f" alt="$ G$"
data:image/s3,"s3://crabby-images/d9af4/d9af4e0f4d692cf0a32c0c3e9ae339006d395819" alt="$ \mathtt{(i,k)}$"
data:image/s3,"s3://crabby-images/e8c10/e8c1011179efb8d64035e088e325dfb02b2ccfcc" alt="$ \mathtt{(k,j)}$"
data:image/s3,"s3://crabby-images/bf875/bf875267914aab4a6f3564992c734de9566afc95" alt="$ \ensuremath{\mathtt{i}}$"
data:image/s3,"s3://crabby-images/6f421/6f42179b7ad9247b50a2f3f11bf15b04c285572d" alt="$ \ensuremath{\mathtt{j}}$"
data:image/s3,"s3://crabby-images/ce2b6/ce2b6836dcbb6ac5efc205e77d3746ffc379c210" alt="$ \ensuremath{\mathtt{k}}$"
data:image/s3,"s3://crabby-images/cef7e/cef7e12369e62ad58095bc8ac0ce5205fc725560" alt="$ G$"
data:image/s3,"s3://crabby-images/44793/4479306ada14ef26e5d00e51f609928cf4f1c9db" alt="$ O(\log \ensuremath{\mathtt{n}})$"
Source: https://opendatastructures.org/ods-java/12_1_AdjacencyMatrix_Repres.html
0 Response to "Adjacency Matrix Example in Java"
Post a Comment