HDOJ-1016 Prime Ring Problem(DFS)
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)的更多相关文章
- hdu 1016 Prime Ring Problem(dfs)
Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- hdu 1016 Prime Ring Problem (dfs)
一切见凝视. #include <cstdio> #include <iostream> #include <cstring> #include <algor ...
- hdu 1016 Prime Ring Problem(DFS)
Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- hdoj - 1258 Sum It Up && hdoj - 1016 Prime Ring Problem (简单dfs)
http://acm.hdu.edu.cn/showproblem.php?pid=1258 关键点就是一次递归里面一样的数字只能选一次. #include <cstdio> #inclu ...
- HDU 1016 Prime Ring Problem(素数环问题)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1016 Prime Ring Problem Time Limit: 4000/2000 MS (Jav ...
- HDU 1016 Prime Ring Problem(经典DFS+回溯)
Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- HDOJ1016 Prime Ring Problem(DFS深层理解)
Prime Ring Problem 时间限制: 200 ...
- HDU1016 Prime Ring Problem(DFS回溯)
Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- UVA - 524 Prime Ring Problem(dfs回溯法)
UVA - 524 Prime Ring Problem Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & % ...
随机推荐
- Mac系统升级到10.9(mavericks)时安装php扩展问题解决(转)
问题一: 执行执行 phpize 报错: grep: /usr/include/php/main/php.h: No such file or directory grep: /usr/include ...
- 【Java】在JTable中设置鼠标监听器,点击操作对应数据
最终效果 鼠标点击JTable中任一数据,修改相应的信息. 确定点击的行和列 package com.dao; import java.awt.event.MouseAdapter; import j ...
- hdu 5400 Arithmetic Sequence(模拟)
Problem Description A sequence b1,b2,⋯,bn are called (d1,d2)-arithmetic sequence ≤i≤n) such that ≤j& ...
- 我所理解的设计模式(C++实现)——中介者模式(Mediator Pattern)
概述: 假设我们开发一个图片处理软件,里面肯定包括很多相关功能,比如说剪切,旋转,滤镜,美化等等,而我们这些功能所要处理的对象是固定的,就是我们所显示的那张图片.但是我们不能把所有的功能罗列到一个ta ...
- Redis安全
安全 执行在可信环境 Redis的安全设计是在"Redis执行在可信环境"这个前提下做出的.在生产环境执行时不能同意外界直接连接到Redisserver上.而应该通过应用程序进行中 ...
- SRM 588 D2 L3:GameInDarknessDiv2,DFS
题目来源:http://community.topcoder.com/stat?c=problem_statement&pm=12710 采用DFS搜索,第一次写的时候忘了加访问标志,结果状态 ...
- C++ MPICH
假设一个C++的MPI程序在单机上能够跑.可是在多机上跑会报下面错误: Fatal error in MPI_Send: Unkown error class , error stack. 解决方法: ...
- C# WPF 建立无边框(标题栏)的登录窗口
前言:笔者最近用c#写WPF做了一个项目,此前未曾做过完整的WPF项目,算是一边学一边用,网上搜了不少资料,效率当然是不敢恭维的,有时会在一些很简单的问题上纠结很长时间,血与泪的教训可不少. 不过,正 ...
- JavaScript深拷贝和浅拷贝
1. 基本类型 和 对象类型 他们最大的区别就是在于他们的传值方式. 基本类型是传值 对象类型就是传引用. 这里复制一份obj叫做obj2, 这里修改了obj2的b为100 同时也修改了obj1.b. ...
- Javascript基础Function
函数声明与表达式 function someFunc(){ alert("这是一个函数"); } var func=function(){ alert("函数表达式&qu ...