Playing on Graph

Vova and Marina love offering puzzles to each other. Today Marina offered Vova to cope with the following task.

Vova has a non-directed graph consisting of n vertices and m edges without loops and multiple edges. Let’s define the operation of contraction two vertices a and b that are not connected by an edge. As a result of this operation vertices a and b are deleted and instead of them a new vertex x is added into the graph, and also edges are drawn from it to all vertices that were connected with a or with b (specifically, if the vertex was connected with both a and b, then also exactly one edge is added from x to it). Thus, as a result of contraction again a non-directed graph is formed, it contains no loops nor multiple edges, and it contains (n - 1) vertices.

Vova must perform the contraction an arbitrary number of times to transform the given graph into a chain of the maximum length. A chain of length k ( k ≥ 0) is a connected graph whose vertices can be numbered with integers from 1 to k + 1 so that the edges of the graph connect all pairs of vertices (i, i + 1) (1 ≤ i ≤ k) and only them. Specifically, the graph that consists of one vertex is a chain of length 0. The vertices that are formed as a result of the contraction are allowed to be used in the following operations of contraction.The picture illustrates the contraction of two vertices marked by red.

Help Vova cope with his girlfriend’s task. Find the maximum length of the chain that can be obtained from the resulting graph or else determine that it is impossible to obtain the chain.


The first line contains two integers n, m (1 ≤ n ≤ 1000, 0 ≤ m ≤ 100 000) — the number of vertices and the number of edges in the original graph.

Next m lines contain the descriptions of edges in the format a i, b i (1 ≤ a i, b i ≤ na i ≠ b i), which means that there is an edge between vertices a i and b i. It is guaranteed that there is at most one edge between each pair of vertexes.


If it is impossible to obtain a chain from the given graph, print  - 1. Otherwise, print the maximum possible number of edges in the resulting chain.



5 4
1 2
2 3
3 4
3 5




4 6
1 2
2 3
1 3
3 4
2 4
1 4




4 2
1 3
2 4




In the first sample test you can contract vertices 4 and 5 and obtain a chain of length 3.

In the second sample test it is initially impossible to contract any pair of vertexes, so it is impossible to achieve the desired result.

In the third sample test you can contract vertices 1 and 2 and obtain a chain of length 2.


#include <bits/stdc++.h>

using namespace std;

int const N = 123456;

vector<int> edges[N];
int d[N], q[N], color[N], pv[N], comp[N];

int get(int v) {
return pv[v] == v ? v : (pv[v] = get(pv[v]));

int main() {
int n, m;
scanf("%d%d", &n, &m);
for (int i = 0; i < n; i++) pv[i] = i;
    for (int i = 0; i < m; i++) {
        int v, u;
        scanf("%d%d", &v, &u);
        pv[get(v)] = get(u);
    for (int start = 0; start < n; start++) {
        fill(d, d + n, -1);
        fill(color, color + n, -1);
        d[start] = 0;
        int head = 0;
        int tail = 0;
        q[tail++] = start;
        color[start] = 0;
        while (head < tail) {
            int v = q[head++];
            comp[get(start)] = max(comp[get(start)], d[v]);
            for (int i : edges[v]) {
                if (d[i] == -1) {
                    d[i] = d[v] + 1;
                    color[i] = color[v] ^ 1;
                    q[tail++] = i;
                } else if (color[v] == color[i]) {
                    return 0;
    int ans = 0;
    for (int i = 0; i < n; i++) if (get(i) == i) ans += comp[i];
    printf("%d\n", ans);