社区讨论
8个RE
P1219[USACO1.5] 八皇后 Checker Challenge参与者 4已保存回复 4
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 4 条
- 当前快照
- 1 份
- 快照标识符
- @m5oobna5
- 此快照首次捕获于
- 2025/01/09 09:52 去年
- 此快照最后确认于
- 2025/11/04 11:51 4 个月前
CPP
#include<bits/stdc++.h>
#include<cstdlib>
#include<cstdio>
#include<cmath>
using namespace std;
int a[100],b[100],c[100],d[100];
int tot;
int n;
int print()
{
if(tot<=2)
{
for(int k=1;k<=n;k++)
cout<<a[k]<<" ";
cout<<endl;
}
tot++;
}
void queen(int i)
{
if(i>n)
{
print();
return;
}
else
{
for(int j=1;j<=n;j++)
{
if((!b[j])&&(!c[i+j])&&(!d[i-j+n]))
{
a[i]=j;
b[j]=1;
c[i+j]=1;
d[i-j+n]=1;
queen(i+1);
b[j]=0;
c[i+j]=0;
d[i-j+n]=0;
}
}
}
}
int main()
{
cin>>n;
queen(1);
cout<<tot;
return 0;
}
回复
共 4 条回复,欢迎继续交流。
正在加载回复...