zoukankan      html  css  js  c++  java
  • HDOJ_ACM_Prime Ring Problem

    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
     
  • 相关阅读:
    基本概念和术语
    Html中的<label>标签
    shell17echo打印带颜色的文字
    shell-15 &的三种不同
    shell-14 多个命令以分号隔开
    shell-13 tee管道可以重定向但是不截流
    shell-12实用cat完成文件复制
    shell-11输入内容到文件
    shell-10kill杀死作业号和进程号
    shell-9前后台切换
  • 原文地址:https://www.cnblogs.com/chuanlong/p/3031972.html
Copyright © 2011-2022 走看看