社区讨论

这两种码有区别吗?

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 条回复,欢迎继续交流。

正在加载回复...