http://acm.hdu.edu.cn/showproblem.php?pid=1016

题意:输入n,代表有一个包含n个节点的环,在环中的节点中填入1,2...n-1,n,要求填入的数与左边的数之和,与右边的数之和,都为素数

输出所有符合要求的环(第一个数总为1)

用DFS模拟,从第2位到第n位依次选取一个与上一个选取的数之和为素数的数

直到选取完第n个数,判断第n个数和1之和是否为素数,是则输出,否则不进行操作,判断完毕返回上一层

直到遍历完所有情况

*:因为素数必然是奇数,所以一条符合要求的素数环每两个相邻的数肯定是一奇一偶

然而当n为奇数且不等于1时,不管怎么排列,总会出现相邻的两个的数同为奇数或同为偶数,使得两者之和必是偶数,不是素数

所以,当n为奇数且不等于1时,可以不用进行处理,剪枝50%

**:但是杭电的数据里n貌似都是偶数,特判n和不特判n的时间花费都差不多,所以并没什么卵用

# include <stdio.h>
# include <math.h>
# include <string.h> int Prime[50], Ring[25], n;
bool Flag[25]; bool IsPrime(int num)
{
int t = sqrt(double(num));
for(int i = 3; i <= t; i++)
if(num % i == 0)
return false;
return true;
} void DFS(int Depth)
{
if(Depth == n + 1)//若以全部选择完毕
{
if(Prime[Ring[Depth - 1] + 1])//查看最后一个和第一个之和是否是素数
{
printf("1");
for(int i = 2; i <= n; i++) printf(" %d", Ring[i]);
printf("\n");
}
return ;
} for(int i = 2; i <= n; i++)
{
if(!Flag[i] && Prime[i + Ring[Depth - 1]])//i与上一个选的数之和是否是素数
{
Ring[Depth] = i;
Flag[i] = true;//每选取一个数就将其标记 DFS(Depth + 1); Flag[i] = false;//搜索完选取该数之后的所有可能后,取消标记
}
}
} int main()
{
for(int i = 3; i < 50; i += 2) Prime[i] = 1;
Prime[2] = 1;
for(int i = 3; i < 50; i += 2)
{
if(IsPrime(i))
{
for(int j = i * 2; j < 50; j += i)
Prime[j] = 0;
}else Prime[i] = 0;
}//素数打表 int Case = 0;
while(scanf("%d",&n) != EOF)
{
printf("Case %d:\n", ++Case); if(n == 1)
printf("1\n");
else if(n % 2 == 0)
{
memset(Flag, false, sizeof(Flag));
Flag[1] = true;
Ring[1] = 1;//第一个始终为1
DFS(2);
} printf("\n");
} return 0;
}

  

HDOJ-1016 Prime Ring Problem(DFS)的更多相关文章

  1. hdu 1016 Prime Ring Problem(dfs)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  2. hdu 1016 Prime Ring Problem (dfs)

    一切见凝视. #include <cstdio> #include <iostream> #include <cstring> #include <algor ...

  3. hdu 1016 Prime Ring Problem(DFS)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  4. hdoj - 1258 Sum It Up && hdoj - 1016 Prime Ring Problem (简单dfs)

    http://acm.hdu.edu.cn/showproblem.php?pid=1258 关键点就是一次递归里面一样的数字只能选一次. #include <cstdio> #inclu ...

  5. HDU 1016 Prime Ring Problem(素数环问题)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1016 Prime Ring Problem Time Limit: 4000/2000 MS (Jav ...

  6. HDU 1016 Prime Ring Problem(经典DFS+回溯)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  7. HDOJ1016 Prime Ring Problem(DFS深层理解)

      Prime Ring Problem                                                                       时间限制: 200 ...

  8. HDU1016 Prime Ring Problem(DFS回溯)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  9. UVA - 524 Prime Ring Problem(dfs回溯法)

    UVA - 524 Prime Ring Problem Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & % ...

随机推荐

  1. js笔记01

    js编写页面特效动态脚本类型的语言变量:存储数据(日常生活中的东西,比如电视,手机,电脑,出生年份...)语法: var obj=value; obj不能为数字开头,且区分大小写 value对应数据类 ...

  2. java获取项目地址或tomcat绝对地址

    在java项目中获取文件的路径,不管是相对路径还是绝对路径,其本质都是通过绝对路径去寻找. 获取项目地址 request.getSession().getServletContext().getRea ...

  3. javascript自定义浏览器右键菜单

    javascript自定义浏览器右键菜单   在书上看到document对象还有一个contextmenu事件,但是不知为什么w3school中找不到这个耶... 利用这个特性写了个浏览器的右键菜单, ...

  4. 程序员的绘图利器 — Gnuplot

      介绍 Gnuplot is a command-line program that can generate two- and three-dimensional plots. It is fre ...

  5. 普通用户登录PLSQL后提示空白OK对话框错误

    问题描述: 1.普通域账号登录域成员服务器后,打开PLSQL正常,输入用户名密码登录后提示一个空白的OK对话框,点确定后又返回到输入用户密码界面. 2.在CMD窗口下调用SQLPLUS登录数据库时报如 ...

  6. 针对淡入淡出的定时轮播效果js

    如果不使用jquery的fadeIn和fadeOut的接口和不适用animate情况下,如果要做用js实现淡入淡出轮播效果,我所想到的办法就是使用css3新特性transition(注意好兼容性). ...

  7. js调用百度地图搜索功能

    引用百度jsApi <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&a ...

  8. EF数据建模(一)

    大中型软件开发过程中常会使用ORM技术,ORM全称是“对象-关系映射Object-Relation-Mappping”.是将数据库中的数据对象的形式表现出来,并将通过面向对象的方式将这些对象组织起来, ...

  9. android码农神器 偷懒工具 android懒人框架 LoonAndroid 3 讲解

    LoonAndroid 3.0 Loonandroid是一个注解框架,不涉及任何UI效果,目的是一个功能一个方法,以方法为最小颗粒度对功能进行拆解.把功能傻瓜化,简单化,去掉重复性的代码,隐藏复杂的实 ...

  10. ORACLE触发器概述之【语句触发器】【weber出品】

    一.触发器概述 与表,视图,模式,或者数据库相关的PL/SQL过程,当触发条件被触发时,自动执行 分类: 1.语句触发器 2.行触发器 二.语句触发器 1. 什么是语句触发器 语句触发器,是指当执行D ...