社区讨论

站外题求助!

灌水区参与者 5已保存回复 11

讨论操作

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

当前回复
11 条
当前快照
1 份
快照标识符
@lzm5hlmt
此快照首次捕获于
2024/08/09 11:31
2 年前
此快照最后确认于
2024/08/09 13:00
2 年前
查看原帖
错误方式:RE
代码:
CPP
#include<bits/stdc++.h>
using namespace std;
int search(int);
void print();
bool pd(int,int);
int n;
int a[888];
bool b[888];
int total=0;
int main(){
	cin>>n;
	search(1);
	return 0;
}
int search(int t){
	for(int i=1;i<=n;i++){
		if((pd(a[t-1],i))&&(!b[i])){
			a[t]=i;
			b[i]=1;
			if(t==n){if(pd(a[n],a[1])) print();}
			search(t+1);
			b[i]=false;
		}
	}
}
void print(){
	if(total==1) return ;
	++total;
	for(int j=1;j<=n;j++){
		cout<<a[j]<<" ";
	}
	cout<<endl;
}
bool pd(int a,int b){
	int d=2,c=a+b;
	while(d<=sqrt(c)&&c%d!=0) d++;
	if(d>sqrt(c)) return true;
	else return false;
}
求助!!!

回复

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

正在加载回复...