社区讨论
这两种码有区别吗?
P1219[USACO1.5] 八皇后 Checker Challenge参与者 4已保存回复 6
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 6 条
- 当前快照
- 1 份
- 快照标识符
- @mi6uel26
- 此快照首次捕获于
- 2025/11/20 10:59 4 个月前
- 此快照最后确认于
- 2025/11/20 10:59 4 个月前
RT,学了题解第一篇自己打了一下,发现0和1差了好多。。。
AC码:
CPP#include<bits/stdc++.h>
using namespace std;
int n,top,a[100],b[100],c[100],d[100];
void s(int i)
{
if(i>n)
{
if(top<=2)
{
for(int k=1;k<=n;k++)
printf("%d ",a[k]);
printf("\n");
}
top++;
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;
s(i+1);
b[j]=0,c[i+j]=0,d[i-j+n]=0;
}
}
}
}
int main()
{
scanf("%d",&n);
s(1);
printf("%d",top);
return 0;
}
WA码:
CPP#include<bits/stdc++.h>
using namespace std;
int n,top,a[100],b[100],c[100],d[100];
void s(int i)
{
if(i>n)
{
if(top<=2)
{
for(int k=0;k<n;k++)//这里!
printf("%d ",a[k]);
printf("\n");
}
top++;
return;
}
else
{
for(int j=0;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;
s(i+1);
b[j]=0,c[i+j]=0,d[i-j+n]=0;
}
}
}
}
int main()
{
scanf("%d",&n);
s(1);
printf("%d",top);
return 0;
}
没看出来有啥区别的说。。。
回复
共 6 条回复,欢迎继续交流。
正在加载回复...