社区讨论

求助AT C

学术版参与者 6已保存回复 9

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
9 条
当前快照
1 份
快照标识符
@lo35dcnu
此快照首次捕获于
2023/10/24 01:04
2 年前
此快照最后确认于
2023/10/24 01:04
2 年前
查看原帖
RT
CPP
#include<bits/stdc++.h>
using namespace std;
int n,m,a[15][15],nn[15],vis[15],can[15],x;
long long ans;
void dfs(){
	bool vs=1;
	for(int i(1);i<=11;i++)
	can[i]=0;
	for(int i(1);i<=m;i++){
		if(vis[i])
		for(int j(1);j<=nn[i];j++)
		can[a[i][j]]=1;
	}
	for(int i(1);i<=n;i++)
	if(!can[i])
	vs=0;
	if(vs){
	++ans;
	return;
	}
	for(int i(1);i<=m;i++){
		if(!vis[i]){
			vis[i]=1;
			dfs();
			vis[i]=0;
		}
	}
}
int main(){
	cin>>n>>m;
	for(int i(1);i<=m;i++){
		cin>>nn[i];
		for(int j(1);j<=nn[i];j++)
		cin>>a[i][j];
	}
	dfs();
	cout<<ans;
	return 0;
}

回复

9 条回复,欢迎继续交流。

正在加载回复...