## Educational DP Contest AtCoder O - Matching

View as PDF

Points: 12
Time limit: 1.4s
Memory limit: 1G

Problem type

There are men and women, both numbered .

For each , the compatibility of Man and Woman is given as an integer . If , Man and Woman are compatible; if , they are not.

Taro is trying to make pairs, each consisting of a man and a woman who are compatible. Here, each man and each woman must belong to exactly one pair.

Find the number of ways in which Taro can make pairs, modulo .

#### Constraints

• All values in input are integers.
• is or .

#### Input Specification

The first line will contain the integer .

The next lines will each contain integers, .

#### Output Specification

Print the number of ways in which Taro can make pairs, modulo .

#### Sample Input 1

3
0 1 1
1 0 1
1 1 1

#### Sample Output 1

3

#### Explanation For Sample 1

There are three ways to make pairs, as follows ( denotes a pair of Man and Woman ):

#### Sample Input 2

4
0 1 0 0
0 0 0 1
1 0 0 0
0 0 1 0

#### Sample Output 2

1

#### Explanation For Sample 2

There is one way to make pairs, as follows:

#### Sample Input 3

1
0

#### Sample Output 3

0

#### Sample Input 4

21
0 0 0 0 0 0 0 1 1 0 1 1 1 1 0 0 0 1 0 0 1
1 1 1 0 0 1 0 0 0 1 0 0 0 0 1 1 1 0 1 1 0
0 0 1 1 1 1 0 1 1 0 0 1 0 0 1 1 0 0 0 1 1
0 1 1 0 1 1 0 1 0 1 0 0 1 0 0 0 0 0 1 1 0
1 1 0 0 1 0 1 0 0 1 1 1 1 0 0 0 0 0 0 0 0
0 1 1 0 1 1 1 0 1 1 1 0 0 0 1 1 1 1 0 0 1
0 1 0 0 0 1 0 1 0 0 0 1 1 1 0 0 1 1 0 1 0
0 0 0 0 1 1 0 0 1 1 0 0 0 0 0 1 1 1 1 1 1
0 0 1 0 0 1 0 0 1 0 1 1 0 0 1 0 1 0 1 1 1
0 0 0 0 1 1 0 0 1 1 1 0 0 0 0 1 1 0 0 0 1
0 1 1 0 1 1 0 0 1 1 0 0 0 1 1 1 1 0 1 1 0
0 0 1 0 0 1 1 1 1 0 1 1 0 1 1 1 0 0 0 0 1
0 1 1 0 0 1 1 1 1 0 0 0 1 0 1 1 0 1 0 1 1
1 1 1 1 1 0 0 0 0 1 0 0 1 1 0 1 1 1 0 0 1
0 0 0 1 1 0 1 1 1 1 0 0 0 0 0 0 1 1 1 1 1
1 0 1 1 0 1 0 1 0 0 1 0 0 1 1 0 1 0 1 1 0
0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 1 1 0 0 1
0 0 0 1 0 0 1 1 0 1 0 1 0 1 1 0 0 1 1 0 1
0 0 0 0 1 1 1 0 1 0 1 1 1 0 1 1 0 0 1 1 0
1 1 0 1 1 0 0 1 1 0 1 1 0 1 1 1 1 1 0 1 0
1 0 0 1 1 0 1 1 1 1 1 0 1 0 1 1 0 0 0 0 0

#### Sample Output 4

102515160

#### Explanation For Sample 4

Be sure to print the number modulo .