【CodeVS1031】质数环

Description

一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数。如下图是一个大小为6的质数环。为了方便描述,规定数环上的第一个数字总是1。如下图可用1 4 3 2 5 6来描述。若两个质数环,数字排列顺序相同则视为本质相同。现在要求你求出所有本质不同的数环。

Input

只有一个数N,表示需求的质数环的大小。如:

Output

每一行描述一个数环,如果有多组解,按照字典序从小到大输出。如:

Sample Input

6

Sample Output

1 4 3 2 5 6

1 6 5 2 3 4

HINT

n<=17

题解

#include<iostream>
using namespace std;
int vis[18]={0};
int a[18]={0};
int ans = 1,n;
int prime[40]={0};
int judgeprime(int x)
{
    if (x == 1) return 0;
    else if (x == 2) return 1;
    else for (int i=2;i<=x-1;i++)
    {
        if (x%i == 0) return 0;
    }
    return 1;

}
void print()
{
    for (int i=1;i<=n;i++) cout<<a[i]<<" ";
    cout<<endl;
}
void search(int x,int cnt)
{
    if (cnt == n && prime[x+1]) print();
    for (int i=1;i<=n;i++)
    {
        if (prime[x+i] && !vis[i])
        {
            vis[i]=1;
            a[cnt+1]=i;
            search(i,cnt+1);
            vis[i]=0;
        }
    }
}
int main()
{
    for (int i=1;i<=40;i++) prime[i] = judgeprime(i);
    cin>>n;
    vis[1]=1;
    a[1]=1;
    search(1,1);
    return 0;
} 
时间: 2024-12-17 08:39:36

【CodeVS1031】质数环的相关文章

codevs1031 质数环

一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上的第一个数字总是1.如下图可用1 4 3 2 5 6来描述.若两个质数环,数字排列顺序相同则视为本质相同.现在要求你求出所有本质不同的数环. 思路: 1.首先素数环,就一定要进行素数判定,考虑n<=17,可以直接暴力求出来,或者说直接可以开一个数组,把与i的和为素数的j从小到大记录下来 2.由于要输出字典序最小的方案,所以第一个一定是一

深度优先搜索 codevs 1031 质数环

codevs 1031 质数环 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上的第一个数字总是1.如下图可用1 4 3 2 5 6来描述.若两个质数环,数字排列顺序相同则视为本质相同.现在要求你求出所有本质不同的数环. 输入描述 Input Description 只有

1031 质数环(深搜练习)

题目网站:http://codevs.cn/problem/1031/ 题目描述 Description 一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上的第一个数字总是1.如下图可用1 4 3 2 5 6来描述.若两个质数环,数字排列顺序相同则视为本质相同.现在要求你求出所有本质不同的数环. 输入描述 Input Description 只有一个数N,表示需求的质数环的大小.如: 输

1031 质数环

1031 质数环 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上的第一个数字总是1.如下图可用1 4 3 2 5 6来描述.若两个质数环,数字排列顺序相同则视为本质相同.现在要求你求出所有本质不同的数环. 输入描述 Input Description 只有一个数N,表示

codevs 1031 质数环

一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上的第一个数字总是1.如下图可用1 4 3 2 5 6来描述.若两个质数环,数字排列顺序相同则视为本质相同.现在要求你求出所有本质不同的数环. 输入描述 Input Description 只有一个数N,表示需求的质数环的大小.如: 输出描述 Output Description 每一行描述一个数环,如果有多组解,按照字典序从小到大输出.如

[Wikioi 1031]质数环---HBNU的童鞋过来看看

题目描述 Description 一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上的第一个数字总是1.如下图可用1 4 3 2 5 6来描述.若两个质数环,数字排列顺序相同则视为本质相同.现在要求你求出所有本质不同的数环. 输入描述 Input Description 只有一个数N,表示需求的质数环的大小.如: 输出描述 Output Description 每一行描述一个数环,如果有

深搜-质数环

题目描述 Description 一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上的第一个数字总是1.如下图可用1 4 3 2 5 6来描述.若两个质数环,数字排列顺序相同则视为本质相同.现在要求你求出所有本质不同的数环. 输入描述 Input Description 只有一个数N,表示需求的质数环的大小.如: 输出描述 Output Description 每一行描述一个数环,如果有

【Codevs1080】质数环

http://codevs.cn/problem/1031/ 不讲什么,预处理素数+搜索 // <C.cpp> - Sun Oct 9 12:58:23 2016 // This file is made by YJinpeng,created by XuYike's black technology automatically. // Copyright (C) 2016 ChangJun High School, Inc. // I don't know what this program

CodeVS 1031 质数环(DP)

题目大意: http://codevs.cn/problem/1031/ #include <iostream> #include <cmath> #include <algorithm> #include <string> using namespace std; int arr[17] = {0}; bool f[17] = {false}; bool isPrime(int a) { if(a == 0) return false; if(a == 1