AT_dp_o Matching
题目描述
有 $N$ 名男性和 $N$ 名女性。男性编号为 $1, 2, \ldots, N$,女性也编号为 $1, 2, \ldots, N$。
对于每一对 $i, j$($1 \leq i, j \leq N$),男性 $i$ 和女性 $j$ 的匹配情况由整数 $a_{i, j}$ 给出。如果 $a_{i, j} = 1$,则男性 $i$ 和女性 $j$ 匹配良好;如果 $a_{i, j} = 0$,则匹配不好。
太郎君想要将所有匹配良好的男女分别配对,组成 $N$ 对。每个男性和每个女性都必须恰好属于一对。
请问有多少种组成 $N$ 对的方法?请输出对 $10^9 + 7$ 取模的结果。
输入格式
输入通过标准输入给出,格式如下:
> $N$
> $a_{1, 1}\ a_{1, 2}\ \ldots\ a_{1, N}$
> $a_{2, 1}\ a_{2, 2}\ \ldots\ a_{2, N}$
> $\vdots$
> $a_{N, 1}\ a_{N, 2}\ \ldots\ a_{N, N}$
输出格式
输出组成 $N$ 对的方法数,对 $10^9 + 7$ 取模。
说明/提示
## 限制条件
- 所有输入均为整数。
- $1 \leq N \leq 21$
- $a_{i, j}$ 仅为 $0$ 或 $1$。
## 样例解释 1
组成配对的方法有以下 $3$ 种。用 $(i, j)$ 表示男性 $i$ 和女性 $j$ 的配对。
- $(1, 2),\ (2, 1),\ (3, 3)$
- $(1, 2),\ (2, 3),\ (3, 1)$
- $(1, 3),\ (2, 1),\ (3, 2)$
## 样例解释 2
组成配对的方法有以下 $1$ 种。
- $(1, 2),\ (2, 4),\ (3, 1),\ (4, 3)$
## 样例解释 4
不要忘记输出对 $10^9 + 7$ 取模的结果。
由 ChatGPT 4.1 翻译