NN 个人围坐一圈,有 MM 对朋友关系。
第 ii 对朋友关系是指,编号是 aiai 的人和编号是 bibi 的人是朋友。
现在要给他们安排座位,要求所有相邻的人不能是朋友。
问共有多少种方案?
如果两个方案只有旋转角度不同,则我们将其视为一种方案。
输入格式
第一行包含两个整数 N,MN,M。
接下来 MM 行,每行包含一对 ai,biai,bi。
输出格式
数据范围
3≤N≤103≤N≤10,
0≤M≤N(N−1)20≤M≤N(N−1)2,
1≤ai
所有输入均为整数。
输入样例1:
输出样例1:
输入样例2:
输出样例2:
112512
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = 11;
bool g[N][N], st[N]; // g[i][j]表示i 与 j的关系
int n, m;
int pos[N]; // 下标上是谁
int res = 0;
void dfs(int u) {
if (u == n) {
if (g[pos[n - 1]][pos[0]]) return;
res ++;
return;
}
for (int i = 1; i <= n; ++i) {
if (!st[i] && !g[i][pos[u - 1]]) {
st[i] = true;
pos[u] = i;
dfs(u + 1);
st[i] = false;
}
}
}
int main() {
cin >> n >> m;
while (m --) {
int a, b;
cin >> a >> b;
g[a][b] = true; g[b][a] = true;
}
pos[0] = 1;
st[1] = true;
dfs(1);
cout << res << endl;
return 0;
}