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

只有一个数N,表示需求的质数环的大小。如:
每一行描述一个数环,如果有多组解,按照字典序从小到大输出。如:
6
1 4 3 2 5 6
1 6 5 2 3 4
#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
using namespace std;
int n,f[20]={0},a[20];
int zh(int x,int y)
{
int r=x+y;
for (int i=2;i<=ceil(sqrt(r));i++)
if (r%i==0) return 0;
return 1;
}
void print()
{
for (int i=1;i<=n;i++)
cout<<a[i]<<' ';
cout<<endl;
}
int xs(int t)
{
{
for (int i=2;i<=n;i++)
if ((! f[i])&&zh(a[t-1],i))
{
a[t]=i;
f[i]=1;
if (t==n&&zh(a[n],a[1]))print();
else xs(t+1);
f[i]=0;//回溯
} }
}
int main()
{ f[1]=1;
a[1]=1;
cin>>n;
xs(2);
return 0;
}
codevs 1031 质数环的更多相关文章
- 深度优先搜索   codevs 1031 质数环
		codevs 1031 质数环 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 一个大小为N(N<=17)的质数环是 ... 
- codevs——1031 质数环
		1031 质数环 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Description 一个大小为N(N<=17 ... 
- AC日记—— codevs 1031 质数环(搜索)
		题目描述 Description 一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上 ... 
- codevs1031 质数环
		一个大小为N(N<=17)的质数环是由1到N共N个自然数组成的一个数环,数环上每两个相邻的数字之和为质数.如下图是一个大小为6的质数环.为了方便描述,规定数环上的第一个数字总是1.如下图可用1 ... 
- 【Codevs1080】质数环
		http://codevs.cn/problem/1031/ 不讲什么,预处理素数+搜索 // <C.cpp> - Sun Oct 9 12:58:23 2016 // This file ... 
- 「UVA524」 Prime Ring Problem 质数环
		Description 输入正整数n,把整数1,2,-,n组成一个环,使得相邻两个整数之和均为素数.输出时,从整数1开始逆时针排列.同一个环恰好输出一次.n<=16. A ring is com ... 
- codevs 2530大质数
		链接:http://codevs.cn/problem/1530/ 解题思路: 这个题最关键的剪枝还是 因子小于平方根,但不是像原来那样用. 逆转思维,与其说判断哪些是质数,不如说判断哪些不是质数,更 ... 
- codevs 2964 公共素数因数
		提交地址:http://codevs.cn/problem/2964/ 2964 公共素数因数 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 白银 Silver 题解 ... 
- 洛谷P1432 倒水问题(CODEVS.1226)
		To 洛谷.1432 倒水问题 题目背景 In the movie "Die Hard 3", Bruce Willis and Samuel L. Jackson were co ... 
随机推荐
- apache 创建虚拟目录
			<VirtualHost *:83> DocumentRoot "E:\PhpProjects"</VirtualHost><Directory ... 
- Java---StringBuffer()方法的简单应用
			描述:在实际应用中,经常回遇到对字符串进行动态修改.这时候,String类的功能受到限制,而StringBuffer类可以完成字符串的动态添加.插入和替换等操作. 1.构造函数.StringBuffe ... 
- mysql oracle静默 一键安装脚本
			pre-read; 为了达到一键搞定的目的!现Ruiy简单做如下几小条规定 如果你想这么一键来搞定请君莫要违背约束! 1. 下载 `二进制` mysql软件介质版本不限,二进制包务必,源码及rpm ... 
- 深入理解object C中复制对象的用法(二)
			第五.对象的自定义拷贝 对象拥有复制特性,必须实现NSCopying,NSMutableCopying协议,实现该协议的copyWithZone方法和mutableCopyWithZone方法 深拷贝 ... 
- Java中对象的上转型对象
			1. 定义 如果B类是A类的子类或间接子类,当用B类创建对象b并将这个对象b的引用赋给A类对象a时,如: A a;a = new B();ORA a;B b = new B();a = b; 则称A类 ... 
- ssh远程连接不上ubuntu
			问题描述: 1.ubuntu安装了openssh-server,启动了ssh 守护进程,使用端口22 2.在本机可以 ssh 127.0.0.1 连接 3.通过ssh远程(比如用putty 或crt) ... 
- python常用的一些东西——sys、os等
			1.常用内置函数:(不用import就可以直接使用) help(obj) 在线帮助, obj可是任何类型 callable(obj) 查看一个obj是不是可以像函数一样调用 ... 
- Android ImageView  点击更换头像
			首先搭建布局 主界面布局: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" ... 
- codeforces 148D之概率DP
			http://codeforces.com/problemset/problem/148/D D. Bag of mice time limit per test 2 seconds memory l ... 
- 经典C面试题
			12个有趣的C语言面试题 面试题C 摘要:12个C语言面试题,涉及指针.进程.运算.结构体.函数.内存,看看你能做出几个! 1.gets()函数 问:请找出以下代码里的问题: #include< ... 
