标签:搜索与回溯

题目:

从1到20这20个数摆成一个环,要求相邻的两个数的和是一个素数。

算法分析:

非常明显,这是一道回溯的题目。从1开始,每个空位有20种可能,只要填进去的数合法:与前面的数不相同;与左边相邻的数的和是一个素数。第20个数还要判断和第1个数的和是否素数。

算法流程:

1、数据初始化;

2、递归填数:判断第i个数填入是否合法;

A、如果合法:填数;判断是否到达目标(20个已填完):是,打印结果;不是,递归填下一个;

B、如果不合法:选择下一种可能;

题解:

#include <iostream>
#include <cmath>
using namespace std; bool b[21]={0};
int a[21]={0};
int search(int);
int print();
bool pd(int,int);
int main()
{
search(1);
return 0;
}
int search(int t)
{
for (int i=1;i<=20;i++)
if(pd(a[t-1],i)&&(!b[i]))
{
a[t]=i;
b[i]=1;
if(t==20)
{
if(pd(a[20],a[1]))
print();
}
else search(t+1);
b[i]=0; }
}
int print()
{
for(int j=1;j<=20;j++)
cout<<a[j]<<' ';
cout<<endl;
}
bool pd(int x,int y)
{
int k=2;
while(k<=sqrt(x+y)&&(x+y)%k!=0)k++;
if(k>sqrt(x+y))return 1;
else return 0;
}

知识点:

  • 素数筛法
void ifprime()
{ //打表法将1到40之间所有的素数用1标记放入数组中对应位置,其余数用0标记
for(int i=2;i<40;i++)
prime[i]=1;
prime[1]=0; for(int i=2;i<40;i++)
for(int j=2*i;j<=40;j+=i)
prime[j]=0;
}
  • 素数定义法
bool pd(int x,int y)
{
int k=2;
while(k<=sqrt(x+y)&&(x+y)%k!=0)k++;
if(k>sqrt(x+y))return 1;
else return 0;
}

错解:

忘记了1到20不能重复,搜索写的也有问题

//1到20素数环
#include <iostream>
using namespace std;
int a[21];
int nas[40];
int check()
{ //素数筛
for(int i=2;i<=40;i++)nas[i]=1;
nas[1]=0;
for(int i=2;i<40;i++)
for(int j=2*i;j<40;j+=i)
{
nas[j]=0;
}
} int search(int k)
{ if(k==20)
{ for(int i=1;i<=20;i++)
if(nas[a[1]+a[20]])
for(int j=1;j<=20;j++)
cout<<a[j];
}
for(int i=1;i<=20;i++)
{
if(nas[a[k]+i])
{
a[k+1]=i;
search(k+1);
}
a[k+1]=0;
search(k);
}
}
int main()
{ check();
for(int i=1;i<=20;i++)
{
a[1]=i;
search(1);
for(int j=1;j<=20;j++)a[j]=0;
} return 0;
}

洛谷UVA524 素数环 Prime Ring Problem的更多相关文章

  1. UVA524 素数环 Prime Ring Problem

    题目OJ地址: https://www.luogu.org/problemnew/show/UVA524 hdu oj 1016:  https://vjudge.net/problem/HDU-10 ...

  2. 素数环 Primg Ring Problem

    素数环 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=84562#problem/C 题意: 输入正整数n,把整数1~n组成一个 ...

  3. HDU - 1016 Prime Ring Problem 经典素数环

    Prime Ring Problem A ring is compose of n circles as shown in diagram. Put natural number 1, 2, ..., ...

  4. Prime Ring Problem素数环(HDU1016)

    Prime Ring Problem 思路:先看成一条链,往里头填数,满足任意相邻两数和为质数(这可以打表预处理出40以内的所有质数,扩展的时候枚举),填完了后检查首尾是否满足条件.字典序可以采用扩展 ...

  5. uva 524 prime ring problem——yhx

      Prime Ring Problem  A ring is composed of n (even number) circles as shown in diagram. Put natural ...

  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. Prime Ring Problem + nyoj 素数环 + Oil Deposits + Red and Black

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

  8. [HDU 1016]--Prime Ring Problem(回溯)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1016 Prime Ring Problem Time Limit: 4000/2000 MS (Jav ...

  9. Prime Ring Problem

    Problem Description A ring is compose of n circles as shown in diagram. Put natural number 1, 2, ... ...

随机推荐

  1. Webpack 入门指迷

    大概算是一份教程吧, 只不过效果肯定不如视频演示之类的好..Webpack 最近在英文社区上经常看到, 留了心, 但进一步了解是通过下边的视频:视频: How Instagram.com Works, ...

  2. 时间选择器 element

    <el-date-picker type="datetime" placeholder="选择上线日期" :picker-options="st ...

  3. Avtiviti工作流规范 BPM与BPMN

    进过长时间的轮转,重拾Activiti,因为最近在智联上看到多家公司的需求上写的,都要熟悉工作流引擎,也就是activiti所以重拾 之前看的视屏是activiti5,我觉得版本有点低,所以打算看一下 ...

  4. fabric1.4 网络操作

    建立第一个网络 进入对应目录 $ cd fabric-samples/first-network 在first-network目录下有两个自动化脚本byfn.sh和eyfn.sh, 这两个脚本的启动顺 ...

  5. 虚拟PWN初探

    前言 之前看到星盟Q群里面的消息,Freedom师傅在B站直播关于虚拟pwn入门的公开课,然后就去听了一波,感觉受益匪浅.之前一直以为虚拟pwn是超级复杂的东西,今年打比赛也遇到了好几次,一直无从下手 ...

  6. SpringBoot整合MinIO

    今天因为公司的需求接触到这个东西,我们先来看下MinIO的官网简介 MinIO 是一个基于Apache License v2.0开源协议的对象存储服务.它兼容亚马逊S3云存储服务接口,非常适合于存储大 ...

  7. Python 面试题 字符串 删除多少个字符使得出现做多的字符数量大于等于字符串长度的一半.

    str1 = input() num = {} for i in set(str1): num[i]=str1.count(i) max_value = max(num.values()) n=abs ...

  8. mysql浅谈--事务ACID特性

    mysql MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管 ...

  9. 常见重构技巧 - 5种方式去除多余的if else

    常见重构技巧 - 去除多余的if else 最为常见的是代码中使用很多的if/else,或者switch/case:如何重构呢?方法特别多,本文带你学习其中的技巧. 常见重构技巧 - 去除多余的if ...

  10. MySQL<=>是什么鬼

    官网描述 NULL-safe equal. This operator performs an equality comparison like the = operator, but returns ...