您的位置:首页 > 其它

uva 524 prime ring problem——yhx

2016-05-16 10:04 501 查看
Prime Ring Problem
A ring is composed of n (even number) circles as shown in diagram. Put natural numbers

into each circle separately, and the sum of numbers in two adjacent circles should be a prime.



Note: the number of first circle should always be 1.


Input

n (0 < n <= 16)


Output

The output format is shown as sample below. Each row represents a series
of circle numbers in the
ring beginning from 1 clockwisely and anticlockwisely. The order of numbers
must satisfy the above requirements.

You are to write a program that completes above process.

1 #include<cstdio>
2 #include<cstring>
3 bool prm[35],vis[20];
4 int a[20],n;
5 bool ck(int x)
6 {
7     int i;
8     for (i=2;i*i<=x;i++)
9       if (x%i==0) return 0;
10     return 1;
11 }
12 void dfs(int p)
13 {
14     int i,j,k,x,y,z;
15     if (p==n+1)
16     {
17         if (prm[a
+a[1]])
18         {
19             printf("%d",a[1]);
20             for (i=2;i<=n;i++)
21               printf(" %d",a[i]);
22             printf("\n");
23         }
24         return;
25     }
26     for (i=2;i<=n;i++)
27       if (vis[i]==0&&prm[i+a[p-1]])
28       {
29           a[p]=i;
30           vis[i]=1;
31           dfs(p+1);
32           vis[i]=0;
33       }
34 }
35 int main()
36 {
37     int i,j,k,p,q,x,y,z,t;
38     bool bbb=0;
39     for (i=2;i<=35;i++)
40       prm[i]=ck(i);
41     a[1]=1;
42     t=0;
43     while (scanf("%d",&n)==1)
44     {
45         if (bbb) printf("\n");
46         bbb=1;
47         memset(vis,0,sizeof(vis));
48         vis[1]=1;
49         printf("Case %d:\n",++t);
50         dfs(2);
51     }
52 }


素数环。注意边界。注意每组数据间的回车(虽然题上没说)。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: