标签:des style io ar os 使用 sp java for
#include<stdio.h>
#include<string.h>
int num[25],ans[25],vis[25],n;
bool Isprime(int n)
{
int i;
for(i = 2; i < n; i++)
if(n % i == 0)
break;
if(i >= n)
return true;
return false;
}
int dfs(int now,int next,int x)
{
if(!Isprime(n+next))//如果当前的数与将要找的下一个数和不是素数
return 0;
ans[x] = next;
if(x == n && Isprime(next+1))//找到
{
for(int i = 1; i <= n; i++)
if(i!=n)
printf("%d ",ans[i]);
else
printf("%d\n",ans[i]);
return 0;
}
vis[next] = 1;
for(int i = 2; i <= n; i++)
if(vis[i]==0 && dfs(next,i,x+1))
break;
vis[next] = 0;
return 0;
}
int main()
{
int kase = 1;
while(~scanf("%d",&n))
{
memset(ans,0,sizeof(ans));
if(n==1)
{
printf("1\n");
continue;
}
memset(vis,0,sizeof(vis));
for(int i = 1; i <= n; i++)
num[i] = i;
ans[1] = 1;
printf("Case %d:\n",kase++);
for(int i = 2; i <= n; i++)
dfs(1,i,2);
printf("\n");
}
return 0;
}
HDU1016_Prime Ring Problem【DFS】
标签:des style io ar os 使用 sp java for
原文地址:http://blog.csdn.net/lianai911/article/details/41411909