Problem Description
A ring is compose of n circles as shown in diagram. Put natural number 1, 2, ..., n 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 < 20).
 

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. Print solutions in lexicographical order.

You are to write a program that completes above process.

Print a blank line after each case.
 

Sample Input
6
8
 

Sample Output
Case 1:
1 4 3 2 5 6
1 6 5 2 3 4

Case 2:
1 2 3 8 5 6 7 4
1 2 5 8 3 4 7 6
1 4 7 6 5 8 3 2
1 6 7 4 3 8 5 2
 

 

Codes

View Code
 1 #include <stdio.h>
 2 #include <string.h>
 3 #define N 20
 4 int primeMap[N + N];  //record which num is prime
 5 int isUsed[N + 5];    //judge if the num is used 
 6 int store[N + 5];     //record the path
 7 int n, count = 1; 
 8 void Initializing()  // 0 means prime, 1 means not prime
 9 {
10     int i, j;
11     for (i = 4; i < 40; i++)
12     {
13         for (j = 2; j <= i / 2; j++)
14         {
15             if (i % j == 0)
16             {
17                 primeMap[i] = 1;
18                 break;
19             }
20         }
21     }
22 }
23 void DFS(int step)
24 {
25     int i;
26     //the exit condition
27     if (step == n && primeMap[store[step] + 1] == 0)
28     {
29         for(i = 1; i < n; i++)
30             printf("%d ",store[i]);
31         printf("%d\n", store[n]);
32     }
33     //find the available num
34     for (i = 2; i <= n; i++)
35     {
36         //is not prime or the num is used
37         if (primeMap[store[step] + i] == 1 || isUsed[i] == 1)
38             continue;
39         //recursion
40         isUsed[i] = 1;
41         store[step + 1] = i; 
42         DFS(step + 1);
43         isUsed[i] = 0;
44     }
45 }
46 int main()
47 {
48     Initializing();
49     while (scanf("%d",&n) != EOF)
50     {
51         memset(isUsed,0,sizeof(isUsed));
52         store[1] = 1;
53         printf("Case %d:\n", count++);
54         //remove the odd, because it's useless
55         if (n % 2 == 0)
56             DFS(1);
57         puts("");
58     }
59     return 0;
60 }

 

 

Recommend
JGShining
 
posted on 2013-04-20 09:37  MrMission  阅读(487)  评论(0编辑  收藏  举报