This library solves the problem of dynamic connectivity online.
In the problem of dynamic connectivity we have a graph and receive queries to add or remove an edge. We also receive queries asking us whether there is a path between a pair of vertices. In the online version of the problem, we receive the queries one by one and must answer them immediately. The goal is to answer the queries as effeciently as possible.
This library also supports duplicate edges.
The library provides a single class - dnc::DynamicConnectivity.
The class provides the following methods:
-
DynamicConnectivity(int n)
- Constructor - creates a graph with
$n$ vertices and no edges.
- Constructor - creates a graph with
-
void insert_edge(int u, int v)
- Adds an edge between vertices
$u$ and$v$ . - The vertices are numbered from
$0$ to$n-1$ . - If the edge already exists, another copy of it is added.
- Adds an edge between vertices
-
bool delete_edge(int u, int v)
- Removes an edge between vertices
$u$ and$v$ . - If such edge does not exist, nothing happens.
- Returns whether the edge was removed.
- Removes an edge between vertices
-
bool is_connected(int u, int v)
- Returns whether there is a path between vertices
$u$ and$v$ . - If
$u = v$ , the function returns true.
- Returns whether there is a path between vertices
-
unsigned connected_components()
- Returns the number of connected components in the graph.
The header file for this library - dnc.h
- is located in include/
.
After running make
, the static library libdnc.a
will reside in lib/
.
The file examples/dynamic_connectivity_example.cpp
shows one possible use of this library.
The executable for this binary can be compiled with make example
and will appear in bin/
.
There is also a testing script test.sh
. Using an input generator test/gen.py
, it will continuously
generate inputs and compare them against a verified offline implementation at test/offline.cpp
. The
test will end if the outputs of the two implementations differ.