Count BFS Graph
문제
You are currently researching a graph traversal algorithm called the Breadth First Search (BFS). Suppose you have an input graph of nodes (numbered from to ). The graph is represented by an adjacency matrix , for which node can traverse to node if is , otherwise it is . Your algorithm will output the order the nodes are visited in the BFS. The pseudocode of the algorithm is presented as follows.
BFS(M[1..N][1..N]):
let A be an empty array
let Q be an empty queue
append 1 to A
push 1 to Q
while Q is not empty:
pop the front element of Q into u
for v = 1 to N:
if M[u][v] == 1 and v is not in A:
append v to A
push v to Q
return A
During your research, you are interested in the following problem. Given an array such that is a permutation of to and . How many simple undirected graph with nodes and adjacency matrix such that ? Since the answer can be very large, calculate the answer modulo .
A simple graph has no self-loop ( for 1 ≤ i ≤ N) and there is at most one edge that connects a pair of nodes. In an undirected graph, if node is adjacent to node , then node is also adjacent to node ; formally, for 1 ≤ u < v ≤ N.
Two graphs are considered different if there is an edge that exists in one graph but not the other. In other words, two graphs are considered different if their adjacency matrices are different.
입력
The first line consists of an integer (2 ≤ N ≤ 5000).
The second line consists of integers . The array is a permutation of to and .
출력
Output an integer representing the number of simple undirected graphs with nodes and adjacency matrix such that . Since the answer can be very large, output the answer modulo .
예제
예제 1
3 1 2 3
3
예제 2
3 1 3 2
1
예제 3
5 1 3 2 4 5
17
예제 4
11 1 2 3 4 5 6 7 8 9 10 11
379394847