比赛 防止浮躁的小练习v0.9 评测结果 AATTTTTTTT
题目名称 放棋子 最终得分 20
用户昵称 NVIDIA 运行时间 8.037 s
代码语言 C++ 内存使用 0.28 MiB
提交时间 2016-11-07 16:25:33
显示代码纯文本
#include<cstdio>
#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstring>
using namespace std;
int n,sum=0;
bool a[200][200],y[200]={0};
void WORK(int k)
{
	if (k==n) 
	{
		sum++;
		return;
	}
	for (int i=0;i<n;i++)
	{
		if (a[k][i]==0&&y[i]==0){
			a[k][i]=y[i]=1;
			WORK(k+1);
			a[k][i]=y[i]=0;
		}
	}
}
int main()
{
    freopen("chess_2016.in","r",stdin);
    freopen("chess_2016.out","w",stdout);
    scanf("%d",&n);
    for (int i=0;i<n;i++)
    for (int j=0;j<n;j++) 
	scanf ("%d",&a[i][j]);
    WORK(0);
    printf("%d",sum);
    return 0;
}