社区讨论

qiuzhu2

P1219[USACO1.5] 八皇后 Checker Challenge参与者 5已保存回复 6

讨论操作

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

当前回复
6 条
当前快照
1 份
快照标识符
@mi6tuxne
此快照首次捕获于
2025/11/20 10:44
4 个月前
此快照最后确认于
2025/11/20 10:44
4 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int ok(int);
void out();
int a[1000];
int n,t;
int main() {
    cin>>n;
	int i=1;
	while(i>0) {
		do
			a[i]++;
		while(!ok(i)&&a[i]<=n);
		if(a[i]>n)
			i--;
		else if(i<n) {
			i++;
			a[i]=0;
		} else {
		    t++;
		    if(t<=3)
			    out();
		}
	}
	printf("%d",t);
	return 0;
}
int ok(int i) {
	for(int j=1; j<i; j++) {
		if(a[i]==a[j]||i-j==abs(a[i]-a[j]))
			return 0;
	}
	return 1;
}
void out() {
    for(int i=1; i<=n; i++)
		cout<<a[i]<<" ";
	puts("");
}

与人知道为什么90吗 (最后一个点TLE)

回复

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

正在加载回复...