DFS hdu 1016
2666 ワード
http://acm.hdu.edu.cn/showproblem.php?pid=1016
data:image/s3,"s3://crabby-images/1ba98/1ba98d012a02a6e4ccc95c42706bb70dde63c278" alt="DFS hdu 1016_第1张图片"
data:image/s3,"s3://crabby-images/4f818/4f818f60341173a396663f171033d993712054cb" alt="DFS hdu 1016_第2张图片"
data:image/s3,"s3://crabby-images/693b4/693b41a51c213125fcb6080fbd36d5ed9497e5e2" alt="DFS hdu 1016_第3张图片"
#include <iostream>
using namespace std;
int a[30],n,used[40];
int is_prime(int x)
{
for(int i=2;i<x; i++)
if(x%i==0) return 0;
return 1;
}
void dfs(int cur)
{
int i;
if(cur==n && is_prime(a[n]+a[1]))
{
for(i=1;i<n;i++) cout<<a[i]<<" ";
cout<<a[n]<<"
";
return;
}
for(i=2;i<=n;i++)
{
if(used[i]==0 && is_prime(a[cur]+i))
{ a[cur+1]=i ; used[i]=1 ; dfs(cur+1);used[i]=0 ;}
}
}
int main( )
{ int c=1;
while(cin>>n)
{
memset(used,0,sizeof(used)) ;
a[1]=1; used[1]=1;
cout<<"Case "<<c++<<":"<<endl ;
dfs(1);
cout<<endl;
}
}
data:image/s3,"s3://crabby-images/cf476/cf476fd427c5efbda426516b27e5fab0444decdd" alt="DFS hdu 1016_第4张图片"
data:image/s3,"s3://crabby-images/165b5/165b5a876140bb7b59930ccd26f2d9970dfb47e0" alt="DFS hdu 1016_第5张图片"