100 atcoder#ABC054C. [ABC054C] One-stroke Path

[ABC054C] One-stroke Path

Score : 300300 points

Problem Statement

You are given an undirected unweighted graph with NN vertices and MM edges that contains neither self-loops nor double edges. Here, a self-loop is an edge where ai=bi(1iM)a_i = b_i (1 \leq i \leq M), and double edges are two edges where (ai,bi)=(aj,bj)(a_i,b_i)=(a_j,b_j) or $(a_i,b_i)=(b_j,a_j) (1 \leq i. How many different paths start from vertex 11 and visit all the vertices exactly once? Here, the endpoints of a path are considered visited.

For example, let us assume that the following undirected graph shown in Figure 1 is given.

Figure 1: an example of an undirected graph

The following path shown in Figure 2 satisfies the condition.

Figure 2: an example of a path that satisfies the condition

However, the following path shown in Figure 3 does not satisfy the condition, because it does not visit all the vertices.

Figure 3: an example of a path that does not satisfy the condition

Neither the following path shown in Figure 4, because it does not start from vertex 11.

Figure 4: another example of a path that does not satisfy the condition

Constraints

  • 2N82 \leq N \leq 8
  • 0MN(N1)/20 \leq M \leq N(N-1)/2
  • $1 \leq a_i
  • The given graph contains neither self-loops nor double edges.

Input

The input is given from Standard Input in the following format:

NN MM

a1a_1 b1b_1

a2a_2 b2b_2

::

aMa_M bMb_M

Output

Print the number of the different paths that start from vertex 11 and visit all the vertices exactly once.

3 3
1 2
1 3
2 3
2

The given graph is shown in the following figure:

43c0ac53de20d989d100bf60b3cd05fa.png

The following two paths satisfy the condition:

c4a27b591d364fa479314e3261b85071.png

7 7
1 3
2 7
3 4
4 5
4 6
5 6
6 7
1

This test case is the same as the one described in the problem statement.