# Edge cover

In graph theory, an edge cover of a graph is a set of edges such that every vertex of the graph is incident to at least one edge of the set. In computer science, the minimum edge cover problem is the problem of finding an edge cover of minimum size. It is an optimization problem that belongs to the class of covering problems and can be solved in polynomial time.

## Definition

Formally, an edge cover of a graph G is a set of edges C such that each vertex in G is incident with at least one edge in C. The set C is said to cover the vertices of G. The following figure shows examples of edge coverings in two graphs (the set C is marked with red).

A minimum edge covering is an edge covering of smallest possible size. The edge covering number ρ(G) is the size of a minimum edge covering. The following figure shows examples of minimum edge coverings (again, the set C is marked with red).

Note that the figure on the right is not only an edge cover but also a matching. In particular, it is a perfect matching: a matching M in which every vertex is incident with exactly one edge in M. A perfect matching (if it exists) is always a minimum edge covering.

### Examples

• The set of all edges is an edge cover, assuming that there are no degree-0 vertices.
• The complete bipartite graph Km,n has edge covering number max(m, n).

## Algorithms

A smallest edge cover can be found in polynomial time by finding a maximum matching and extending it greedily so that all vertices are covered.[1][2] In the following figure, a maximum matching is marked with red; the extra edges that were added to cover unmatched nodes are marked with blue. (The figure on the right shows a graph in which a maximum matching is a perfect matching; hence it already covers all vertices and no extra edges were needed.)

On the other hand, the related problem of finding a smallest vertex cover is an NP-hard problem.[1]

Looking at the image it already becomes obvious why, for a given minimal edge Cover ${\displaystyle C}$ and maximum matching ${\displaystyle M}$, the following is true: ${\displaystyle |V|=|C|+|M|}$. Counting the edges in the minimal edge cover duplicates the edges in the maximum matching, summing to ${\displaystyle 2*|M|}$ (equaling the number of vertices in the matching), but also counts the unmatched vertices, because they have to be adjacent to an edge in the edge cover.