zoukankan      html  css  js  c++  java
  • HDU 1016:Prime Ring Problem

    Prime Ring Problem

    Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
    Total Submission(s): 25156    Accepted Submission(s): 11234


    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


    </pre><pre name="code" class="cpp">#include<cstdio>
    #include<stdlib.h>
    #include<cstring>
    #include<algorithm>
    #include<iostream>
    
    using namespace std;
    
    int date[25]= {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20};
    int ans[25];
    int n, cnt;
    int flag;
    
    void dfs(int step)
    {
        int temp;
        if(step==n)       //深搜究竟时注意推断首尾是否符合要求
        {
            flag=1;
            temp = ans[0]+ans[n-1];
            if(flag)
            {
                for(int i=2; i*i<=temp; i++)
                    if(temp%i==0)
                    {
                        flag=0;
                        break;
                    }
            }
            if(flag)
            {
                printf("%d", ans[0]);
                for(int i=1; i<n; i++)
                    printf(" %d", ans[i]);
                printf("
    ");
            }
        }
        else
        {
            for(int i=1; i<n; i++)
            {
                if(date[i])
                {
                    temp=ans[cnt-1]+date[i];
                    flag=1;
                    for(int j=2; j*j<=temp; j++)
                    {
                        if(temp%j==0)
                        {
                            flag=0;
                            break;
                        }
                    }
                    if(flag)
                    {
                        ans[cnt++]=date[i];
                        date[i]=0;
                        dfs(step+1);
                        date[i]=ans[--cnt];   //记得将数据的还原处理
                        ans[cnt]=0;
                    }
                }
            }
        }
    }
    
    int main()
    {
        int count=1;
        while(scanf("%d", &n)!=EOF)
        {
            memset(ans, 0, sizeof(ans));
            cnt=1;
            ans[0]=1;
            printf("Case %d:
    ",count++);
            dfs(1);            //从1開始进入搜索
            printf("
    ");      //每次输出后记得加个换行
        }
    
        return 0;
    }
    



  • 相关阅读:
    MYSQL学习笔记——sql语句优化工具
    SQL优化工具SQLAdvisor使用
    SqlServer性能检测和优化工具使用详细
    Sql优化器究竟帮你做了哪些工作
    通俗易懂的php多线程解决方案
    PHP删除数组中空值的方法介绍
    PHP函数
    python函数回顾:dir()
    面向对象封装思想小结
    python函数回顾:all()
  • 原文地址:https://www.cnblogs.com/jhcelue/p/6757921.html
Copyright © 2011-2022 走看看